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entienden castellan 




NUESTROS JUEGOS 
ESTAN HECHOS PARA TI 



Como usuario de MSX. puede que ha- 
yas tenido la sensación de que las casas 
importantes de software te habían olvi- 
dado, rara remediar esa situación. ERBE. 
U. S. GOLD y UL TIMA TE han consegui- 
do convertir al MSX una serie de fabu- 
losos programas pensados para aprove- 
char al máximo las grandes posibilida- 
des de estos ordenadores. Aqui están 
cinco sobresalientes fuegos en cas- A 
sette que van a demostrarte lo aj 
que puede dar de si tu MSX sin M 
que tengas que gastar una for- m 
tuna en 'cartuchos'. m 
Directo desde Norte América m 
llega GROGS REVENGE. rer- M 
sonajes de comic inmensa- m 
mente populares en U.S.A. m 



para producir juegos de una calidad 
única. NIGHTSHADE utiliza "Filma tion II" 
y el resultado es un juego de propor- 
ciones, que superan todo lo hecho hasta 



EfHE 



f :sust 



JSTERS 



el momento en gráficos tridimensionales. 
BOUNDER de Gremlin Graphics es el 
programa que va a poner a prueba tu 
habilidad en el manejo del joystick. Mo- 
ver una pelota de tenis que rebota a 
través de un sinfín de pantallas en las 
que has de controlar los botes para evi- 
tar que caiga donde no debe, es una ta- 
rea de lo más difícil y adictivo y que 
^ ha hecho de este juego que sea N.° 
/ en Inglaterra. Y por u/timo 
I X DAMBUSTERS. Esta simulación 
* \ no necesita presentaciones, se 
■ \ trata de una fiel reconstrucción 
\ de la legendaria misión, que 
\ llevó a cabo durante la II 
\ Guerra Mundial el Escuadrón 
\ ó I 7. y en la que destruye- 



Grog y Thor son dos troglodi- \ 
tas. que se desenvuelven como m 
pueden en la Edad de Piedra... y W 
es que la supervivencia no es fa- ^LiJ 

Cil. Diplodocus. cavernas, rocas, si- 
mas y mil peligros les acechan en e/^ 
juego mas original, que jamas hayas visto. 
"Fi/mation". es una técnica de programa- 
ción creada y desarrollada por Ultímate 



^^^L/ r on á oresa que daba energía a 
" las fabricas de armamento alema- 

i ñas. DAMBUSTERS con su mezcla 
M de simulador, acción y estrategia es 
^Af ya un clasico dentro de los progra- 
f mas de ordenador. Todos estos gran- 
des juegos en cassettes están disponibles 
ahora para tu MSX en todos los grandes 
establecimientos de informática. 
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Editorial 



NUEVAS TENDENCIAS 



Abrumadora ha sido realmente la respuesta al 
sorteo que propusimos en el número especial de 
verano. Ahora llega el momento de comprobar 
si vuestro nombre aparece en la relación de afor- 
tunados. Si estáis incluidos, entonces enhora- 
buena. De lo contrario no desesperéis, es inten- 
ción de quienes hacemos INPUT continuar ofre- 
ciendo la posibilidad de obtener algún premio 
lo más a menudo que permitan las circunstan- 
cias. Este es el caso del ganador en el concurso 
convocado por Anaya Multimedia desde la re- 
vista. Como resultado acudió a la feria PCW en 
Londres uno de los lectores más habilidosos des- 
cifrando claves. Según cuentan las crónicas se di- 
virtió de lo lindo. Septiembre una vez más ha 
sido pródigo en la aparición de rumores y nue- 



vos productos. La feria británica antes mencio- 
nada junto con el Sonimag han servido para 
apreciar cómo parecen confirmarse dos tenden- 
cias de cara al futuro de la microinformática. Por 
un lado los ordenadores destinados a juegos con 
más memoria, capacidades gráficas y sonido, 
siendo buena muestra el nuevo Spectrum+2 y 
los MSX 2. Por otro lado, los ordenadores com- 
patibles PC de bajo precio de venta, situándose 
al alcance de muchos más usuarios, sistemas que 
hasta hace poco eran un lujo asiático para quie- 
nes no fueran empresas o profesionales. El de- 
nominador común de ambas tendencias es la ba- 
jada de precios aplicada en septiembre. De lo 
que no cabe duda es que nos encontramos ante 
el umbral de una nueva etapa. 



LOS MEJORES DE INPUT 

Hemos pensado que es interesante disponer de un ranking que El resultado de las votaciones será publicado en cada número 

ponga en claro, mes a mes, cuáles son los programas preferidos de INPUT. 

de nuestros lectores. Para ello, es obligado preguntaros directamen- Entre los votantes sortearemos 10 cintas de los títulos que pidáis 

te y tener así el mejor termómetro para conocer vuestras preferen- en vuestros cupones. 

cias. Podéis votar por cualquier programa aunque no haya sido co- Nota: No es preciso que cortéis la revista, una copia hecha a 

mentado todavía en INPUT. máquina o una simple fotocopia sirven. 

Enviad vuestros votos a: LOS MEJORES DE INPUT P.° de la Castellana, 93. Planta 14. 28046 Madrid 



ELIGE TUS PROGRAMAS 



Primer titulo elegido L 
Tercer titulo elegido L 
Qué ordenador tienes 
1." Apellido l__i l 



Fecha de nacimiento I 



Dirección I i i i 



Provincia I i i i 



Segundo titulo elegido 



J L 



Programa que te gustaría conseguí 
Nombre I i i i i i i 
2." Apellido Iiiiii 
Teléfono I i i i i i i 



J — I Localidad I i i i i i 



J I I L 



I L 



J I 



J L 



J L 



INPUT MSX N.° 6 



,_l 



PHILIPS A PGR TODAS 



El lodelo HSX2 V6-B235 de Philips 
ha dejado de ser el único ejeiplar 
de nueva generación de la fina 
holandesa. De golpe la oferta se 
aiplia con la gaia recientemente 
presentada en Soniiao . de noibre NHS 

(New Hedía Systets). 
Los tres nuevos equipos presentados 
bajo estas siglas son el NHS 8228 , 
el 8258 y el 8288 (Video Coiputer). 
Es este últiio el que más 
expectación despertó, y es lógico si 
teneios en cuenta que se trata de 
algo total «ente nuevo. 
En efecto, lientras que los modelos 
8228 y 8258 son versiones más o 
■enos renovadas de equipos HSX2, el 
Video Coiputtr es, más que un 
ordenador, un sistema completo de 
adquisición, almacenamiento y 
tratamiento de imágenes de video. 
El equipo periite la edición de las 
cintas de video, incluyendo en ellas 
textos, mezclando y superponiendo 
distintas imágenes, creando e 
incorporando distintos efectos 
especiales, etc. Para estos 
increíbles coietidos, el sistema 
incorpora 128K de RAM de usuario y 
otros 128K de RAM de video, así como 
una unidad de úisktttes de 1M. Por 
supuesto, adeiás de convertir el 
salón de casa en un estudio de 
video, el siteia periite utilizar 
todo el soltmre HSX, al ser 
compatible con el resto de las 
máquinas del estándar. 



KONAMI JUEGA FUERTE 



K onan . que hace poco anunció su 
intención de fabricar y distribuir 
sus propios prograias para Europa , 
tras su aventura con Imagine , no ha 
dejado pasar el tieipo. 
Para los próximos meses, el 
distribuidor de los japoneses para 
nuestro pais, Seria , aununcia los 



siguientes lanzaiientos: 
El superhit Breen Beret en versión 
MSX, Jail Break . que narra la fuga 
de un grupo de presidiarios, 
Basketball para recordar los 
mundiales de baloncesto, Niqhtmare : 
una aventura gráfica, la versión HSX 
de The Boonies . Iron Horse ; uno de 
los arcades de lis éxito en el 86, 
Yie Ar Kunq Fu II , Sao Lin Road y 
Neiesis. 

Todos los títulos aparecerán en 
cartucho para HSX. 

También se está preparando la 
versión de Salaiander . un prograia 
que se anuncia como el Mega Juego 
del 1987. 

Un buen tontón de novedades que 
iremos comentando en próxiios 
n úieros. 



LOCOS POR LA MUSICA 



Con el nuevo sisteia Philips , de 
noibre Husic Module , se amplían de 
foria espectacular los horizontes 
musicales de los usuarios de HSX. 
El sisteia incluye un cartucho con 
un sintetizador FH de nueve canales 
de sonido independientes, con 68 
sonidos pregrabados y un conjunto de 
28 ritios de acompañamiento (que 
incluyen estilo pop, clásico, 
español, etc) 

El conjunto incorpora además un 
•uestreador, con el que sera posible 
grabar, manipular y reproducir 
posteriormente cualquier sonido 
externo, que llegue al sisteia a 
través del licrófono incorporado o 
de la entrada de audio. A una 
frecuencia de luestreo de l6KHz, el 
•uestreador periite almacenar hasta 
4 segundos de grabación, 
transferibles a cassette o diskette. 

El modulo periite asimismo el 
control de tono o la incorporación 
de un eco, de retardo variable, con 
los que hacer experimentos en el 
campo de los efectos especiales. 

Por si fuera poco, se ha incluido 
un interface HIDI. (el estándar 
musical) con conexiones In, fluí y 



Tftru. 

Todas estas opciones se manejan 
desde 8 lenós básicos, presentados 
mediante una serie de iconos. 



MAS SOFT PARA MSX2 



Un buen tontón de programas, 
especialmente diseñados para 
aprovechar las posibilidades 
gráficas de la segunda generación 
HSX . es lo que nos ofrece Idealoqic . 
Para eipezar nos encontramos con la 
colección Telar i ui; un conjunto de 
aventuras gráficas interactivas, con 
argumentos basados en novelas de 
éxito, que al parecer ya están 
disponibles en nuestro lercado. Los 
títulos anunciados son: Cita con 
Raía, de Arthur Clarcke . El Haflo de 
Qi, de L Frank , Dragón Morid, La 
Isla del Tesoro . Farenheit 451, 
Aiazon y por ultimo Perrv Hason en 
El caso del asesinato en el 
Handarin . 

Aparte de esta serie, Idealoqic 
presenta un atractivo paquete, de 
noibre Aerobic . para HSX2 . destinado 
a los que quieren lantenerse en 
forma. El prograia utiliza 
profusaiente los gráficos, y una 
serie de técnicas de animación, para 
presentar y explicar los distintos 
ejercicios. Una serie de temas 
■usicales, coipuestos expresamente 
para este solt por un buen 
profesional de la lúsica, acoipañan 
y larcan el ritió de los distintos 
ejercicios. 

Ludicbit es el noibre de otro de los 
lanzaiientos anunciados. Se trata de 
una colección de títulos, 
fundamentalmente de arcades, pan 
HSXl y 2, entre los que cabe 
destacar una versión pinball 3D, 
catalogada como la priiera del 
■ercado mundial. 

La lista de novedades teriina con 
dos paquetes de utilidad; 
Supersprites y Side Pack . el priiero 
destinado a la edición y animación 
de spritts y el segundo a servir de 
calculadora, listín telefónico y 
block de notas. 
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LA MEMORIA DE VIDEO 
DE MSX: SCREEN 3 




El modo de gráficos de baja resolu- 
ción (SCREEN 3) tiene, ai menos apa- 
rentemente, poca utilidad. Los gráficos 
en este modo de pantalla son bastante 
grotescos, sin embargo, resulta intere- 
sante para la programación de juegos 
y, sobre todo a la hora de hacer gran- 
des y vistosos rótulos. 

Además de la parte de memoria 
destinada a contener la información 
relativa a los sprites, sólo existen en 
este modo de pantalla dos bloques de 
memoria para almacenar toda la infor- 
mación necesaria. 



PUNTOS EN SCREEN 3 

En este modo de pantalla hay un 
bloque de memoria VRAM que con- 
tiene la información relativa a la re- 
presentación de puntos en la pantalla. 

Este trozo de memoria se llama Ta- 
bla del generador de patrones y ocupa 
1536 bytes. Su dirección de comienzo 



viene dada por BASE (17) que es 
igual a 0. 

En este modo 3, los puntos de la 
imagen o pixels tienen una superficie 
que es 16 veces la de los pixels del 
modo 2 (gráficos de alta resolución). 
Es decir, el lado de un pixel es 4 ve- 
ces el lado de un pixel en SCREEN 2: 
la x (eje horizontal de izquierda a de- 
recha) varía de a 255 y la y (eje ver- 
tical de arriba a abajo) varía de a 
191. Lo que ocurre es que en lugar de 
tener 256 pixels horizontales por 192 
verticales (en total 49152 puntos), te- 
nemos 64 superpixels horizontales por 
48 verticales (en total 3072 superpun- 
tos), y si situamos un punto en las 
coordenadas (100,101), el ordenador 
dibuja un superpixel en el punto co- 
rrespondiente al par de coordenadas 
que se obtienen como el entero resul- 
tado de dividir la x y la y del punto en 
cuestión por 4, es decir, (100/4,101/4) 
= (25,25). 

Para estudiar la tabla 17 imagine- 
mos la pantalla como una trama de 32 




1 






;RUTINA PARA VOLCAR TABLAS 




2 






;17 Y 15 DE 


VRAM 


A RAM 




3 








0RG 


0A368H 




4 








LOAD 


0A368H 




5 






; TABLA 17 








6 


A368 


210000 




LD 


HL,0 


; INICIO VRAM 


7 


A36B 


010006 




LD 


BC,1536 


;L0NGITUD 


8 


A36E 


1151C3 




LD 


DE,50001 


;INICI0 RAM 


9 


A371 


GD5900 




CALL 


0059H 


; MUEVE BLOQUE 


10 






■ 








11 






; TABLA 15 








12 


A374 


210008 




LD 


HL,2048 


; INICIO VRAM 


13 


A377 


010003 




LD 


BC,768 


; LONGITUD 


14 


A37A 


1152C9 




LD 


DE,51538 


;INICI0 RAM 


15 


A37D 


CD5900 




CALL 


0059H 


; MUEVE BLOQUE 


16 


A380 


C9 




RET 






17 








END 







6 INPUT 




PUNTOS EN SCREEN 3 



COPIANDO PUNTOS 



TRANSFERENCIA VRAM-RAM 
EN CODIGO MAQUINA 



EFECTO FLASH 



cuadros horizontales que numerare- 
mos de a 31 y 24 cuadros ver- 
ticales que numeraremos de 
a 23, tal como hacíamos al ha- 
blar de SCREEN 2 (ver figura 
1). Supongamos ahora la pan- 
talla dividida en 6 franjas hori- 
zontales de 32 cuadros hori- 
zontales por 4 verticales. 
La figura 2 representa la 
franja superior (franja número 1). En 
ella vemos que cada cuadro está divi- 
dido en 2 mitades, una encima de la 
otra y que numeramos con (la supe- 
rior) y 1 (la inferior) . A cada una de 
estas 2 mitades le corresponde un byte 
y 2 superpixels. Cada superpixel se co- 
rresponde con una mitad del byte; el 
superpixel de la izquierda con los 4 bits 
de mayor peso (al que asignaremos el 
número 1) y el de la derecha con los 
4 de menor peso (número 0). Así en 
cada byte se almacenan dos colores, 
correspondientes a cada uno de los su- 
perpixels. Esta es toda la información 
que contienen los bytes de esta tabla. 



AI dar la orden SCREEN 3, todos los 
nibbles (un nibble es medio byte) de 
todos los bytes de esta tabla toman el 
número (entre y 15) correspondien- 
te al color del fondo (al conectar el or- 
denador, el azul=4). 

Veamos ahora como se correspon- 
den cada pareja de superpixels de la 
pantalla con los bytes de esta tabla: Al 
byte le corresponde la mitad (su- 
perior) del cuadro (0,0), al byte 1 la 
mitad 1 (inferior) del mismo cuadro, 
al byte 2 la mitad del cuadro (0,1), 
que es el situado justo debajo del 
(0,0), y así hasta el byte 7 que está em- 
parejado con la mitad 1 del cuadro 
(0,3). Los colores de la mitad del 
cuadro (1,0) están almacenados en el 
byte 8... y así hasta la mitad 1 del cua- 
dro (31,3) que se almacena en el byte 
255. El byte 256 almacena los colores 
de la mitad del cuadro (0,4),... y el 
byte 1535 los de la mitad 1 del cuadro 
(31,23). 

Para saber que byte le corresponde 
al superpixel 1 de la mitad k del cua- 
dro (i,j) basta aplicar la fórmula: 

(j/4)*256+i*8+2*( jM0D4)+K 

Si 1=0 se tratará del nibble bajo y si 
1=1 se tratará del nibble : a\to. 

Si por ejemplo queremos dibujar un 



1 




; RUTINA PARA VOLCAR TABLAS 




2 




;17 Y 15 DE RAM A VRAM 




3 




0R6 


0A368H 




4 




LOAD 


0A368H 




5 




;TABLA 17 






6 


A368 2151C3 


LD 


HL,50001 


; INICIO RAM 


7 


A36B 010006 


LD 


BC,1536 


/LONGITUD 


8 


A36E 110000 


LD 


DE,0 


; INICIO VRAM 


9 


A371 CD5C00 


CALL 


005 CH 


;MUEVE BLOQUE 


10 










11 




•TABLA 15 






12 


A374 2152C9 


LD 


HL,51538 


;INICI0 RAM 


13 


A377 010003 


LD 


BC,768 


; LONGITUD 


14 


A37A 110008 


LD 


DE,2048 


;INICI0 VRAM 


15 


A37D CD5C00 


CALL 


005 CH 


; MUEVE BLOQUE 


16 


A380 C9 


RET 






17 




END 
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punto de color negro en el superpixel 
1 de la mitad 1 del cuadro (20,19) bas- 
ta escribir el valor hexadecimal 14 
(l=color negro, 4=azul color del fon- 
do) en el byte: 

(19/4)*256+20*8+2*(19M0D4) 
+1=1191 

lo que podemos hacer con auxilio 
de la instrucción VPOKE, así: 

10 SCREEN 3 

20 VPOKE 1191 ,&H14 

30 GOTO 30 



CUADROS IGUALES 



Al hablar de SCREEN 2 veíamos 
que podíamos dividir la pantalla grá- 
fica en 3 franjas horizontales en las 
que podíamos repetir cuadros. 

En el modo multicolor que estamos 
tratando, disponemos de la Tabla de 
Nombres de Patrones (cuya dirección 
de comienzo viene dada por BASE 
(15)=2048). Esta tabla está dividida 
en 4 zonas, pero estas zonas no pare- 
cen estar muy ordenadas. Cada zona 
se corresponde con 6 líneas horizonta- 
les de 32 cuadros cada una (de la cua- 
drícula de la que hablamos al princi- 
pio), de forma que la primera zona 



(zona 1) está formada por los 32 cua- 
dros de las filas 0, 4, 8, 12, 16 y 20, la 
zona 2 por las filas 1, 5, 9. 13, 17 y 21, 
la zona 3 por las filas 2, 6, 10, 14, 18 
y 22 y la zona 4 por las filas 3, 7, 1 1. 
15, 19 y 23. Así cada zona ocupa en 
memoria (a razón de un byte por cua- 
dro) un total de 32*6=192 bytes, y la 
tabla 15 completa ocupa un total de 
192*4=768 bytes. Al dar la orden 
SCREEN 3, los bytes correspondien- 
tes a la primera fila de cada zona tie- 
nen almacenados los números a 31, 
los correspondientes a la segunda fila 
de cada zona, los números 32 a 63... 
y los correspondientes a la fila sexta 
de cada zona, los números 160 a 191. 
De esta forma los números correspon- 
dientes a cada cuadro de la cuadrícula 
son los que se indican en la figura 3. 

Podemos conocer el byte que co- 
rresponde al cuadro (i,j) con auxilio 
de la relación: 

2048+j*32+i 

y el valor que, en principio estará 
almacenado en ese byte será: 

32*(j/4)+i 

Modificando los valores de esta ta- 
bla podemos repetir puntos en la pan- 



12 3 4 



FIGURA 1. CUADRICULA DE LA PANTALLA 



talla, pero siempre dentro de cada 
zona. Es decir, al igual que ocurría en 
SCREEN 2, no se pueden repetir pun- 
tos de zonas distintas. 

Como ejemplo, veremos cómo uti- 
lizando esta tabla podemos escribir un 
rótulo repetido 6 veces en la pantalla. 
Lo que hacemos es escribir en los 
bytes correspondientes a las líneas 4 a 
23 los valores a 31, que son los al- 
macenados en los bytes correspon- 
dientes a las líneas a 3. 



APLICACIONES EN CODIGO 
MAQUINA 

La primera aplicación va a consistir 
en algo que ya hicimos al hablar del 
modo 2, es decir en pasar la VRAM 
a RAM. Hagámoslo en BASIC. 
Como consideración a aquellos que 
dispongan de unidad de disco, alma- 
cenaremos los datos a partir de la po- 
sición 50000. 

La subrutina que pasa las tablas 17 
y 15 a RAM, que podemos incluir en 
nuestros programas es: 

10 CLEAR 200,50000! 
50000 F0R 1=0 T0 1535 
50010 P0KE 50001 ! + I, 

VPEEK(I) 
50020 NEXT I 
50030 F0R 1=2048 T0 2815 
50040 POKE 49490 !+I, 

VPEEK(I) 
50050 NEXT I 
50060 RETURN 

y la que pasa la RAM a VRAM es: 

10 CLEAR 200,50000! 
60000 F0R 1=0 TO 1535 
60010 VPOKE I,PEEK 

(50001 !+I) 
60020 NEXT I 
60030 F0R 1=2048 T0 

2815 

60040 VPOKE I,PEEK 

(49490J+I) 
60050 NEXT I 
60060 RETURN 

Veamos como trabajan estas subru- 
tinas. Incluyamos ambas subrutinas en 
el siguiente programa: 
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29 



— °- 

1 


8 
9 








1 - 2 - 

3 


10 
11 








2- i 

5 


12 
13 








3 2 
7 


14 
15 


- 


■ 















30 
240 
241 
242 
243 
244 
245 



246 
247 



31 
248 
249 
250 
251 
252 
253 
254 
255 



NIBBLE 1 NIBBLE 
ALTO BAJO 



BYTE I 



BYTE I + 1 



FIGURA 2. DISTRIBUCION DE BYTES EN LA TABLA 17 



10 CLEAR 200,50000! 
20 SCREEN 3 
30 OPEN "GRP: " AS #1 
40 PRESET (64,0) 
50 PRINT#1,"H0LA" 
60 FOR 1=2176 T0 

2815 STEP 32 
70 FOR J=0 TO 31 
80 VPOKE I+J,J 
90 NEXT J 
100 NEXT I 
110 GOSUB 50000 
120 SCREEN 3 
130 GOSUB 60000 
140 IF INKEY$="" 

THEN 140 
150 STOP 

Con las sentencias dadas entre las lí- 
neas 20 y 100, se escribe en la panta- 
lla la palabra «HOLA» en gran tama- 
ño seis veces (hemos utilizado la tabla 
15 para repetir patrones). En la línea 
110 se almacena la VRAM en RAM 
(subrutina 50000 a 50060). En la 120 
se actualiza la pantalla y en la línea 
130 la RAM pasa de nuevo a la 
VRAM (subrutina 6000 a 60060). 

El siguiente programa es similar al 
anterior, pero realiza las operaciones 
de guardar la VRAM en RAM y la in- 



versa mediante sendas rutinas en có- 
digo máquina dadas por los Datas de 
las líneas 10000 y 10010. Además in- 
cluimos en estas páginas el código en- 
samblador de ambas rutinas. 

10 CLEAR 200,50000! 
20 FOR 1=1 T0 50 



30 READ A$ 

40 P0KE 523101+1, 

VAL("&H"+A$) 
50 NEXT I 
60 DEFUSR0=52311 ! 
70 DEFUSR1=52336! 
80 SCREEN 3 
90 OPEN "GRP:" AS#1 
100 PRESET (64,0) 
110 PRINT#1 ,"H0LA" 
120 FOR 1=2176 T0 

2815 STEP 32 
130 FOR J=0 T0 31 
140 VPOKE I+J,J 
150 NEXT J 
160 NEXT I 
170 U=USR(0) 
180 FOR 1=1 T0 100 
190 BEEP 
200 NEXT I 
210 SCREEN 3 
220 U=USR1(0) 
230 BEEP 

240 IF INKEY$="" THEN 240 
250 STOP 

10000 DATA 21,00,00,01,00,06, 
1 1 ,51 ,C3,CD, 59,00,21 ,00 
,08,01 ,00,03, 11, 52, C9,C 
D,59,00,C9 

10010 DATA 21,51,C3,01 ,00,06, 
1 1, 00,00, CD, 5 C, 00,21, 52 
,C9,01 ,00,03,11 ,00,08, C 
D,5C,00,C9 



12 3 



28 29 30 31 



321 33| 34 35 



60 61 62 63 



64 65 66 67 



96 97 98 99 



124 125 1261127 



128 129 130131 



156 1571158 159 



160 161 162 163 



1881189 1901191 
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INPUT 9 



1 






; RUTINA PARA INVERTIR COLOR 




2 






;EN SCREEN3 






3 
4 






; REPITE CAMBIO 100 VECES 




5 






ORG 


0A4F1H 




6 






LOAD 


0A4F1H 




7 






• 






8 


A4F1 


DB99 


IN 


A,(99H) 




9 


A4F3 


016400 


LD 


BC,100 




10 


A4F6 


0B 


PRINC: DEC 


BC 


; COMIENZA CUENTA 


11 


A4F7 


21FF00 


LD 


HL,0FFH 


; RUTINA RETARDO 


12 


A4FA 


2B 


RETARDO: DEC 


HL 




13 


A4FB 


7C 


LD 


A,H 




14 


A4FC 


B5 


OR 


L 




15 


A4FD 


20FB 


JR 


NZ, RETARDO 


;FIN RETARDO 


16 


A4FF 


210006 


LD 


HL,1536 


; CAMBIO COLOR 


17 


A502 


2B 


CAMBIA: DEC 


HL 




18 


A503 


CD4A00 


CALL 


4AH 


;LEER VRAM 


19 


A506 


2F 


CPL 






20 


A507 


CD4D00 


TAI 1 




;ESC. EN VRAM 


21 


A50A 


7C 


LD 


A,H 




22 


A50B 


B5 


OR 


L 




23 


A50C 


20F4 


JR 


NZ, CAMBIA 




24 


A50E 


78 


LD 


A,B 


; COMPRUEBA SI 100 


25 


A50F 


B1 


OR 


C 




26 


A510 


20E4 


JR 


NZ, PRINC 




27 


A512 


C9 


RET 






28 






END 







Las rutinas en BASIC tardan, cada 
una 17.24 seg. en ejecutarse, mientras 
que las rutinas en código máquina tar- 
dan ¡¡¡0.04!!! seg. cada una. 



EFECTO FLASH 

La segunda aplicación que vamos a 
ver sirve para conseguir un efecto de 
centelleo, por ejemplo en el rótulo de 
presentación de un programa. La ru- 
tina en código máquina correspon- 
diente cambia, alternativamente los 
colores del fondo y de la tinta en 
SCREEN 3, alterando el contenido de 
la tabla 17. Lo que hace la rutina es 
poner en todos los bytes de esta tabla 
el número complemento a dos del que 
había inicialmente. El siguiente pro- 
grama BASIC incluye un DATA en la 
línea 10000 con los códigos hexadeci- 



males de dicha rutina. En este progra- 
ma hemos inicializado los colores del 
fondo y de la tinta al negro y blanco, 
respectivamente, colores con los que 
resalta más el efecto. La operación de 
cambio se realiza 100 veces antes de 
devolver el control al BASIC. Tam- 
bién incluimos el código ensamblador 
para esta rutina. 



10 CLEAR 200,50000! 
20 F0R 1=1 T0 34 
30 READ A$ 
40 P0KE 500001+1, 

VAL("&H"+A$) 
50 NEXT I 
60 DEFUSR=50001 ! 
70 COLOR 15,1,1 
80 SCREEN 3 
90 0PEN "GRP: " AS#1 
100 PRESET (64,0) 



110 PRINT #1,"H0LA" 
120 F0R 1=2176 T0 

2815 STEP 32 
130 F0R J=0 T0 31 
140 VP0KE I+J,J 
150 NEXT J 
160 NEXT I 
170 U=USRC0) 
180 STOP 

10000 DATA DB,99, 01 ,64,00, 0B, 
21,FF,00,2B,7C,B5,20,FB 
,21 ,00,06 ,2B,CD,4A, 00,2 
F,CD,4D,00,7C,B5,20,F4, 
78,B1,20,E4,C9 

Si quieres modificar la velocidad a 
la que se produce el centelleo, no tie- 
nes más que modificar los valores 4. 
6, 7 y 8 de la sentecia DATA (64, 00, 
FF y 00 respectivamente). Prueba di- 
versos valores y observa los resulta- 
dos. 



lO INPUT 
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I J ^ 

VISITE LA DIVISION dny- 



programo"*" 



TODO SOBRE READ 
Y DATA 



Haciendo que el ordenador lea por 
medio de la sentencia READ un gran 
volumen de datos te puedes ahorrar te- 
ner que teclear programas largos. Pue- 
des usar esta misma técnica para todo, 
desde gráficos hasta índices sencillos. 

Una de las características que hace 
que un ordenador sea tan versátil es 
el uso de variables. Y casi siempre la 
asignación de valores a las variables es 
algo extremadamente sencillo, no tie- 
nes más que escribir, por ejemplo, X 
= 5. Pero hay ocasiones en que la can- 
tidad de información que se quiere uti- 
lizar es tan grande que llega a desbor- 
darte. Aquí es donde encuentran su 
gran utilidad las sentencias DATA y 
sus acompañantes READ y RESTO- 
RE. 

La palabra DATA tiene aquí un sig- 
nificado muy específico. Se suele uti- 
lizar el término «datos» para designar 
una gran variedad de cosas. Por ejem- 
plo, un programa, una rutina en códi- 
go máquina y una matriz almacenada 
en cinta o en diskette, a todo esto se 
le suele llamar a veces «datos». Pero 
en todo este artículo al hablar de da- 
tos, nos estamos refiriendo a las sen- 
tencias DATA y a los elementos que 
contienen. 

El primer método que se suele 
aprender para asignar valores a una 
variable, ya se trate de una variable 
numérica o de una cadena de caracte- 
res, suele ser por medio de una sen- 
tencia INPUT. Pero ésta sólo resulta 
de utilidad cuando es el propio usua- 
rio el que suministra la información al 
ordenador cada vez que se ejecuta un 
programa. 

Muchas veces sin embargo, hay va- 
lores fijos que no tienen que ser intro- 
ducidos ni modificados por el opera- 
dor, por lo que se pueden incorporar 
permanentemente en el programa. 

En este caso y mientras el volumen 
de datos a introducir no sea demasia- 
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do grande, se recurre a las sentencias 
de asignación del tipo: 

10 X-5 

11 LET X=5 

12 A$="ABC" 

13 l FT AS>="Af>( " 

En ellas, todo lo que hay a la dere- 
cha del signo = queda asignado a la 
variable que figura a la izquierda de 
dicho signo. Como ves, puedes omitir 
la palara clave LET sin que haya nin- 
gún problema. Es más, si no la utili- 
zas ahorras memoria. Se ha incluido 
en el BASIC MSX simplemente por- 
que es una palabra clave de uso co- 
mún en otras versiones de este lengua- 
je, y lo que Microsoft pretendía era 
crear una versión BASIC lo más com- 
pleta y estandarizada posible. 

El problema aparece cuando se tra- 



■ COMO FUNCIONAN READ Y DATA 



■ 


LA SENTENCIA RESTORE 


■ 


COMO CONSTRUIR GRAFICOS 


SENCILLOS A PARTIR 


DE LOS DATA 



baja con un gran volumen de datos. 
Utilizar grandes masas de sentencias 
de asignación, además de tedioso a la 
hora de programar, resultaría bastan- 
te ineficiente, haría más lenta la eje- 
cución del programa y consumiría un 
innecesario espacio de memoria. 

Aquí tienes un ejemplo en el que se 
lleva a cabo la asignación de los valo- 
res de cuatro variables, que un supues- 
to programa utiliza a la hora de la pre- 
sentación de documentos: 

10 A$= M Ft.CHA" 

?0 B$- "CLIENTE" 

30 £$="^0. CLIENTE'' 

40 D$= "EMPRESA'' 

50 PFUM A$,B$,C5,DS> 

Para hacer esto mismo podrías utli- 
zar sentencias DATA. El programa 
quedaría así: 




Programación 



10 READ A$,B$,C$,D$ 
20 PRINT A$,B$,C$,D$ 
20 DATA FECHA,CLIENTt / 
NO. CLIENTE EMPRESA 

A la vista del ejemplo, piensa por 
un momento en lo que ocurriría si, en 
lugar de cuatro encabezamientos, el 
programa tuviera que utilizar cincuen- 
ta o cien, todos ellos diferentes. Con 
el primer programa sería necesario in- 
cluir un montón de nuevas sentencias 
de asignación, mientras que con la se- 
gunda versión sólo harían falta una o 
dos más, dependiendo del ordenador 
y del tamaño de los encabezamientos. 



COMO FUNCIONAN LAS 
SENTENCIAS «READ» Y «DATA» 



¿Cómo funcionan realmente las 
sentencias READ y DATA? Cuando 
el ordenador se encuentra con una ins- 
trucción READ, explora todo el pro- 
grama hasta que encuentra la primera 
sentencia DATA. A continuación 
asigna el valor del primer dato de di- 
cha sentencia a la variable que figura 
en la sentencia READ. 




Así, en el programa anterior la ca- 
dena de caracteres «FECHA» queda 
asignada a la variable A$, a continua- 
ción se asigna «CLIENTE» a la varia- 
ble B$, etc. Cuando se han leído to- 
dos los valores de una sentencia 
DATA el ordenador pasa a la senten- 
cia DATA siguiente. 

Las sentencias DATA aparecen 
normalmente al final de los programas 
para «no estorbar» mientras el resto 
del programa se encuentra en fase de 
escritura y depuración. Pero realmen- 
te pueden ir situadas en cualquier par- 
te. El ordenador simplemente ignora 
todas las sentencias DATA a menos 
que una sentencia READ le ordene 
hacer lo contrario. El siguiente pro- 
grama funcionaría perfectamente: 

10 DATA ALEMANIA 

20 PF.AD A$,PS 

30 DATA FRANCIA, ITALIA, 

BELGICA 
40 READ C$,D$ 
50 PRINT A$,B$,C$,D$ 

Sin embargo es evidente que el pro- 
grama resultará mucho más fácil de 
leer si todas las sentencias DATA se 
ponen agrupadas en alguna parte. 

Un programa puede contener tan- 
tas sentencias DATA como sea nece- 
sario. Lo único a tener en cuenta es 
un par de reglas sencillas que hay que 
respetar: Los datos de las sentencias 
DATA deben ir separados por comas 
y colocados en el orden en que el pro- 
grama tenga que leerlos. Se pueden 
incluir tantos datos como se quiera en 
cada sentencia DATA, pero teniendo 
en cuenta que el número de caracte- 
res en una línea no puede exceder 
nunca de 255. En cuanto la línea esté 
llena se empieza otra nueva; el orde- 
nador sigue tomándolas en orden. 



DIFERENTES TIPOS DE «DATA» 



Hasta ahora hemos estado hablan- 
do de sentencias DATA que conte- 
nían cadenas de caracteres, pero tam- 
bién pueden contener números. Lo 
que no puedes hacer es incluir varia- 
bles o expresiones aritméticas en tus 
sentencias DATA. Aunque ello resul- 



te posible en las versiones BASIC de 
otros ordenadores, los MSX no con- 
templan este caso. Por ello si escribes 
algo como esto: 

10 DATA A*5 

ó 

10 DATA 7+3 

e intentas asignar estos valores a va- 
riables numéricas obtendrás un boni- 
to «Syntax error». 

Las variables que aparezcan en la 
sentencia READ tienen que aparecer 
en el mismo orden y ser del mismo 
tipo que los elementos de la sentencia 
DATA. Por ejemplo, para una sen- 
tencia DATA como la siguiente: 

10 DATA PARIS, 1235, ROMA 

es necesario una sentencia READ 
de este tipo: 

10 READ A£,X,BS 

Como puedes observar, la primera 
variable es alfanumérica (termina en 
$) lo que se corresponde con el primer 
dato que figura en la sentencia 
DATA; la cadena de caracteres PA- 
RIS. Lo mismo ocurre con la variable 
B$ y con el dato ROMA. Sin embar- 
go el segundo dato es un valor numé- 
rico (1235), por lo que la variable co- 
rrespondiente de la sentencia READ 
es una variable numérica (x). 



PROBLEMAS QUE PRESENTAN 
LAS LINEAS «DATA» 



Es fácil cometer errores al introdu- 
cir los datos de una sentencia DATA. 
Los principales problemas se presen- 
tan cuando no tienes suficientes ele- 
mentos, o cuando intentas que la sen- 
tencia READ lea datos de tipo equi- 
vocado. Si la sentencia DATA del 
ejemplo anterior hubiera sido teclea- 
da erróneamente de la forma DATA 
1235, PARIS, ROMA te encontrarías 
en primer lugar con que la variable A$ 
leería el dato numérico 1235. En este 
caso no se detectaría ningún tipo de 
error, pero se estaría considerando 
erróneamente el dato numérico como 
una cadena de caracteres. Otro caso 
distinto se plantea cuando se lee el si- 

INPUT 13 



Programo**; 



guíente dato. En este caso la variable 
numérica X intenta leer un dato no 
numérico (PARIS). Aquí ya no hay 
confusión posible; el ordenador detec- 
ta el error y lo indica mediante un 
mensaje del tipo «Syntax error in...» 
indicando el número de la línea 
DATA en la que se ha detectado el 
problema. Como verás donde más cui- 
dado hay que tener es en el primer 
caso, pues el error que se produce no 
lo detecta el ordenador. 

Otro de los problemas más frecuen- 
tes al trabajar con sentencias DATA 
es suministrar menos datos de los ne- 
cesarios. Esto ocurre muchas veces 
cuando estás utilizando un bucle que 
contiene la sentencia READ, como 
ocurre en el programa que veremos a 
continuación. En cuanto cometas un 
error en el parámetro del bucle, o te 
dejes fuera accidentalmente alguno de 
los datos de las sentencias DATA (por 
ejemplo, si en lugar de una coma in- 
cluyes un punto para separar dos va- 
lores, el ordenador creerá que se tra- 
ta de un sólo valor) la máquina inten- 
tará leer valores más allá del final de 
la lista de datos. El resultado será la 
detención del programa y la aparición 
de un mensaje indicando que faltan 
datos «Out of Data in (número de lí- 
nea)». Este tipo de error crea mucha 
confusión entre los principiantes pues 
el número de línea que aparece en el 
mensaje, corresponde a la línea de la 
sentencia READ y no a la de la sen- 



tencia DATA que es donde hay que 
llevar a cabo la correción. 

UNA LISTA SENCILLA 

Aquí tienes un programa que utili- 
za un bucle para leer los datos con las 
sentencias READ y DATA. Es un 
programa muy sencillo de lista de te- 
léfonos. Tú introduces el nombre de 
la persona y el ordenador te presenta 
su número de teléfono. 

5 CLS 

10 LOCATE 6,2:PRINT 

"DIRECTORIO TELEFONICO" 

20 INPUT"Escribe el nombre" 
;R$ 

30 FOR J=1 T0 5 
40 READ N$,T$ 

50 IF N$=R$ THEN LOCATE 1,10: 

PRINT"EL NUMERO DE ";N$; 

" ES ";T$:ST0P 
60 IF N$="FIN" THEN LOCATE 

3,10:PRINTR$;" NO ESTA EN 

LA LISTA" 
70 NEXT J 

500 DATA PEPE, 452 12 34, LUIS, 
876 23 45, ARTURO, 567 34 5 
6,RAUL,784 34 12, FIN, FIN 

Teclea el programa, pero ten la pre- 
caución de utilizar en la línea DATA 
los nombres y números de teléfono de 
tus amigos. Puedes poner todos los da- 
tos que quieras. Lo único que tienes 
que cuidar al final es de ajustar correc- 



tamente el contador de bucle de la lí- 
nea 30. 

Observa que la lista de datos se ter- 
mina con FIN, FIN. De esta forma la 
línea 60 puede comprobar si se ha al- 
canzado el final de la línea. Si el pro- 
grama ha podido leer hasta aquí, sig- 
nifica que no ha encontrado el nom- 
bre, por lo que imprime un mensaje 
para decírtelo. Hay que introducir 
«FIN» dos veces, debido a que la lí- 
nea 40 lee los datos de dos en dos, con 
lo que de no ser así obtendrás un men- 
saje de error de falta de datos. 

Fíjate también que para leer un nú- 
mero de teléfono se considera a éste 
como una cadena de caracteres. Se ha 
hecho así para respetar un signo de 
puntuación, el guión, que evidente- 
mente no puede figurar como un nú- 
mero. Las cadenas de caracteres que 
figuren dentro de una sentencia 
DATA pueden contener espacios, 
pero no pueden contener comas. 
Como los diferentes datos están sepa- 
rados por comas, el ordenador consi- 
deraría la coma como el final de uno 
de los datos. Si te vieras obligado a in- 
troducir en una sentencia DATA una 
cadena de caracteres que contenga 
una coma, tienes que encerrarla entre 
comillas. Sería necesario hacer esto en 
una sentencia DATA como la que fi- 
gura en el ejemplo siguiente: 

10 READ N$,A$,B$,C$ 
20 DATA LUIS PELAEZ, 



LA 

REDACCION i 
CAMBIA L 



DIRECCION 




—Paseo— 

déla 
Castellana 

n*93 
planta, 14 

28046 

-Madrid- 
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"C/PINTO, 25", MURCIA, 2345 
30 PRINT N$,A$,B$,C$ 

USO DE «RESTORE» 

Con los métodos que llevamos ex- 
plicados hasta este momento, un pro- 
grama es capaz de leer mediante una 
sentencia READ la correspondiente 
lista de datos de la sentencia DATA, 
pero sólo lo hará una vez a menos que 
se vuelva a ejecutar de nuevo el pro- 
grama. Si quieres que se vuelvan a leer 
los datos, debes incorporar en tu pro- 
grama una sentencia RESTORE. 

Supongamos por ejemplo que quie- 
res mirar los números de teléfono de 
algunos de tus amigos. La forma in- 
mediata de hacerlo es poner en el pro- 
grama una rutina de «Otra Vez». Sus- 
tituye el STOP en la línea 50 por 
GOTO 80, y a continuación añade las 
siguientes líneas de programa: 

80 LOCATE 0,12:PRINT 
"Quieres otro numero 
(s/n)?" 
90 V$=INKEY$:IF V$="" 

THEN GOTO 90 
100 IF V$="s" 0R V$="S" 

THEN GOTO 5 
110 IF V$="n" 0R V$="N" 
THEN END 

¿Qué sucede cuando intentas ejecu- 
tar el programa? La primera vez el 



programa funciona perfectamente. 
Pero cuando pulsas una tecla para in- 
tentar ejecutarlo por segunda vez, te 
falla porque le faltan datos. Ello se 
debe a que durante la primera ejecu- 
ción llegó hasta el final de la lista de 
datos. Afortunadamente hay una so- 
lución muy sencilla para este proble- 
ma. Teclea: 

15 RESTORE 

Esta vez el programa funciona bien 
todas las veces. Ello se debe a que la 
instrucción RESTORE hace que el or- 
denador vuelva hasta el principio de la 
lista de datos. 

Es una buena idea poner RESTO- 
RE cerca del principio del programa 
durante la fase de desarrollo. Esto te 
evita tener que recorrer todas las lis- 
tas de datos en las pruebas de ejecu- 
ción. Si crees que más adelante te va 
a convenir suprimir dicha línea de 
RESTORE, pon una sentencia REM 
con un mensaje para que te lo recuer- 
de. 

Por medio de RESTORE, puedes 
volver a utilizar una lista de datos tan- 
tas veces como sea necesario. Esto re- 
sulta particularmente útil en progra- 
mas que tienen etiquetas, encabeza- 
mientos, tablas, etc, que serán repeti- 
das en momentos diferentes. Por 
ejemplo, puedes poner los meses del 
año en una lista de datos dentro de 
una sentencia DATA en un programa 



SIGUIENDOLE LA PISTA 
A TUS DATOS 

Sea lo que sea lo que conten- 
gan los datos de tus sentencias 
DATA, todos ellos suelen tener 
una cosa en común: se requiere 
bastante tiempo y trabajo para 
calcularlos y teclearlos. Esto se 
aplica principalmente a la pri- 
mera vez que trabajas con el 
programa, pero puede que tam- 
bién resulte necesario volver so- 
bre el mismo mucho más adelan- 
te. 

La colocación ordenada de los 
datos requiere algo más de tra- 
bajo al principio pero te puede 
ahorrar muchísimo tiempo en el 
futuro. La mejor organización a 
adoptar depende de los propios 
datos. 

Cuando las sentencias DATA 
se usan para definir un bloque 
gráfico o algo por el estilo, or- 
ganiza las líneas del programa 
para que se correspondan direc- 
tamente con las filas del gráfico. 
Si los datos siguen un formato 
que se repite (como en los nú- 
meros de una lista de teléfonos, 
por ejemplo), organiza las líneas 
de programa con todas las entra- 
das de la misma forma. 



GANADORES DE LOS MEJORES DE INPUT MSX 



En el sorteo correspondiente al número 5 entre quienes escribisteis mandando vuestros votos a LOS 
MEJORES DE INPUT han resultado ganadores: 



NOMBRE 


LOCALIDAD 


JUEGO ELEGIDO 


Carlos Revilla Puig 


Barcelona 


Jack the nipper 


Alfonso Salinas Nieto 


Barcelona 


Green Beret 


José Aguilar Camacho 


La Carlota (Córdoba) 


H.E.R.0. 


Susana Munne Serrano 


Barcelona 


Jet Fighter 


J. Antonio Tombilla Martínez 


Vigo (Pontevedra) 


The Dambusters 


Francisco Delmás Soriano 


Castellón 


Billiards 


Fernando Alvarez Reguant 


Suria (Barcelona) 


Gunfright 


Miguel Palma Mur 


Mequinenza (Zaragoza) 


Yie ar kung fu 


M. a José Coreóles Cenón 


Murcia 


Bounder 


Antonio Malagón Camacho 


Cuenca 


Yie ar kung fu 
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de calendario del tipo que sea, el cual 
sin duda hará un repetido uso de di- 
chas tablas. 

La instrucción RESTORE es espe- 
cialmente útil en los casos en los que 
deseas seguir leyendo con READ una 
lista para buscar un determinado ele- 
mento, como es el caso del programa 
de lista telefónica que hemos visto an- 
teriormente. 



USO DE LA SENTENCIA «DATA» 



Las listas de datos que contienen las 
sentencias DATA son extremadamen- 
te útiles en toda clase de programas. 
Puede que hayas hecho uso de ellas en 
los programas de gráficos definidos 
por el usuario y en el dibujo del labe- 
rinto. También hemos visto cómo pue- 
de leer el ordenador los parámetros de 
la música y otros efectos sonoros. 

En los juegos de aventuras, se sue- 
le utilizar con frecuencia gran cantidad 
de líneas de datos en las que se pone 
todo el texto necesario. Los juegos de 
marcianitos escritos en BASIC tam- 
bién usan con frecuencia las sentencias 
DATA para definir personajes y otros 
elementos del juego. 

Los programadores más expertos 
utilizan las sentencias DATA para ha- 
cer programas en código máquina o en 
lenguaje ensamblador. Tales progra- 
mas pueden consistir en un corto bu- 
cle que contiene instrucciones READ, 
para leer los datos almacenados en las 
sentencias DATA, e instrucciones 
POK.E para almacenar dichos datos en 
una determinada zona de memoria. 
Esto es lo que se conoce normalmen- 
te como un «cargador BASIC». 

En una palabra, todo programa que 
contenga texto ordinario, números o 
funciones, puede hacer uso con gran 
provecho de las listas de datos. Con 
un uso cuidadoso estas listas pueden 
convertirse en una poderosa herra- 
mienta de programación. 



USO DE LOS PUNTEROS DE 
«RESTORE»» 



El único problema que presentan 
las sentencias DATA es que siempre 




Los números que figuran a conti- 
nuación de los comandos RESTORE 
se llaman punteros de RESTORE. Di- 
rigen al ordenador hacia una determi- 
nada lista de datos que empieza en el 
correspondiente número de línea. Se- 
gún esto, si pulsas V para tener un 
puente viejo, el puntero de RESTO- 
RE toma el valor 1000. 

De hecho, cuando quieras que el or- 
denador se dirija al primer elemento 
de la lista DATA, no hace falta utili- 
zar un puntero. Si se hace un RESTO- 
RE que no va acompañado por nin- 
gún número de línea, equivale a un 
RESTORE con el número de la pri- 
mera línea DATA. La línea 7 del an- 
terior programa podría haberse escri- 
to igualmente como IF Y$ = «V» 
THEN RESTORE, obteniendo exac- 
tamente el mismo resultado. 

Los punteros de RESTORE son 
muy útiles en la programación de jue- 
gos. Por ejemplo en un juego de ate- 
rrizajes, podrías escribir un programa 
2000 DATA 83,84,85,86,87,88,8 para comprobar si has aterrizado con 
9, 90, 90,90,90,90, 90, 90, 9 suavidad o te has estrellado. Las listas 
0,39,88,^7,86,85,84,83 de datos podrían contener en ese caso 
2010 DATA 4t ,55,63,65,63,55, información para emitir el correspon- 
^2 diente ruido de impacto o una fanfa- 



hay que llamar a la información que 
contienen en la misma sucesión, em- 
pezando por la primera posición. Con 
el uso de RESTORE siempre puedes 
volver al principio de la lista, incluso 
aunque todavía no hayas llegado has- 
ta el final. ¿Pero cómo podrías hacer 
para saltar al centro de una lista? 

El BASIC MSX te brinda una ma- 
nera de hacer esto. En vez de utilizar 
únicamente una lista, puedes usar 
realmente varias, haciendo que el or- 
denador se dirija a la lista apropiada. 
En el programa de gráficos que figura 
más adelante, prueba a introducir las 
siguientes líneas adicionales: 

6 INPUT"Puente viejo o 
moderno"; Y$ 

7 IF Y$="v" THEN 
RFS70RE 1000 

8 IF Y$='V THEN 
FE.ST0RF 2000 

9 IF YSO'V AND YSO'V 
THFN CC.TC, S 
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Progran***" 




/ 



rria victoriosa, y el puntero de RES- 
TORE apuntaría en cada caso a la lis- 
ta correcta. 

USO DE LOS «DATA» EN LOS 
GRAFICOS 

Las sentencias DATA son muy úti- 
les en los programas de gráficos para 
fijar las coordenadas que hay que di- 
bujar y para llamar a las rutinas gráfi- 
cas de la ROM. El uso de los DATA 
de esta manera resulta ideal para las 
formas irregulares, ya que se necesita- 
rían muchas líneas de programa si sólo 
se emplearan instrucciones individua- 
les de impresión o dibujo. 

No obstante existen casos en que 
una sentencia DATA no es de gran 
utilidad. Así ocurre cuando estás di- 
bujando formas muy regulares en las 
que las coordenadas o el contorno grá- 
fico pueden calcularse fácilmente. 

Las sentencias DATA del programa 
que veremos a continuación, han sido 
divididas deliberadamente en varias lí- 
neas. Se ha hecho así porque la pos- 
terior modificación de los datos pue- 
de ser difícil a menos que se tengan 
unas divisiones muy claras; imagínate 



lo que sería volver sobre este progra- 
ma dentro de unos meses e intentar lo- 
calizar y modificar unos cuantos datos 
de cada una de las variables. Natural- 
mente, puedes seguir detenidamente 
la pista de cada una de las instruccio- 
nes READ, pero hacer esto en un pro- 
grama largo es muy tedioso. Por ello 
te recomendamos que fragmentes 
cada grupo de sentencias DATA en 
varias líneas y que además (suponien- 
do que tengas memoria disponible) 
utilices abundantemente las sentencias 
REM para que las cosas te resulten 
más claras. 

El siguiente programa utiliza 
READ y DATA para ayudarte a di- 
bujar un puente. Si introduces y eje- 
cutas el programa por etapas, resulta- 
rá más fácil comprender lo que suce- 
de y comprobar que no te has equivo- 
cado al teclear. Empieza con lo si- 
guiente: 

10 SCREEN2 : FOR T=94 TC 

104 STEP 5 
20 PSET(35,7) 

30 CIRCLE STEP(S7,0),6?„0, 

3.1415 
40 NEXT T 

Esta sección utiliza un bucle FOR 
... NEXT que permite el dibujo de 
tres puntos próximos al lado izquier- 
do de la pantalla y a continuación di- 
buja una línea curva a partir de cada 
uno de dichos puntos. Esta línea cur- 
va es un arco de circunferencia que se 
obtiene con la función CIRCLE. El 
centro se sitúa mediante STEP a 87 pi- 
xels a la derecha de cada uno de los 
puntos. La semicircunferencia se con- 
sigue especificando los ángulos inicial 
y final como y PI (3.1415). 

100 FOR N=18 TC 39 
110 READ A 
120 PSET CN,110) 
130 L INE -S7EPC0,-A) 
132 PSET (N+188,110) 
134 L INE -STLPT0,-A) 
140 NEXT N 

1C00 DATA 70,70,67,67,70,70,6 
0,60,57,57,60,60,57,57,6 
0,60,70,70,67,67,70,70 



Esta sección es la que dibuja las to- 
rres. El bucle situado entre las líneas 
100 y 140, más el número 110 {pixels 
contados a partir del fondo) de las lí- 
neas 120 y 132 dibuja los puntos de la 
base de cada una de las líneas vertica- 
les muy próximas que forman las to- 
rres. 

Seguidamente entran en acción las 
líneas 110 y 1000. La línea 110 dice al 
ordenador que lea en la línea 1000 la 
altura, expresada en pixels, de cada 
una de las 22 líneas verticales. Así, la 
primera línea es 0,70 es decir, vertical 
y de una altura de 70 pixels; la segun- 
da línea es 0,70, la tercera 0,67 y así 
sucesivamente. Si quieres ver cómo va 
sucediendo esto, ensaya a insertar 
temporalmente una instrucción como: 

155 FOR PA=1 T0 1C0:MEXT 

300 PSET (0,75) 

310 UNE -S7EPC255,G) 

3?0 PSET (0,78) 

330 LINE -STEP(255,0) 

Estas líneas son las que se ocupan 
de dibujar la carretera. Por último: 

400 FOR R=-62 TC 182 

STEP 20 
410 PSET (R,78) 
420 READ D 
430 LINE -STEP<0,-R0 
440 NEXT R 

1010 DATA 42,55,63,65, 
63,55,42 

Estas líneas se encargan de dibujar 
los cables verticales que unen el arco 
con la carretera. El bucle FOR ... 
NEXT ayuda a dibujar las posiciones 
de partida de los cables, mientras que 
las líneas 420 y 1010 controlan su altu- 
ra. 

Si quieres que el programa vuelva a 
ejecutarse automáticamente, añádele 
las siguientes líneas: 

5 CLS : RESTORE 
450 FOR J=1 T0 1000 
:NEXT:G0T0 5 

La línea 5 borra la pantalla, permi- 
tiendo luego que el programa lea de 
nuevo los datos. 
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LOGO MSX: EL LENGOAJE : 
DE LA TORTÜGA 



UN LOGO EN CASTELLANO 
LAS TORTUGAS Y SUS FORMAS 



DIBUJANDO CON LA TORTUGA 
PROCEDIMIENTOS EN LOGO 



FUNCIONES MATEMATICAS 



El LOGO nació como un lenguaje de 
programación altamente intuitivo, es- 
tructurado de una forma muy lógica y 
asequible, para aquellos cuyo idioma 
nativo es el inglés. 

Afortunadamente existe ya una ver- 
sión española del LOGO MSX y ahora 
si podemos aprovecharnos de todas las 
ventajas que el lenguaje nos ofrece. 

Aún cuando evidentemente no va- 
ría la estructura, está claro que resul- 
ta más expeditivo ordenar desaparecer 
la tortuga con «esconde la tortuga» 
que con «hide turtle» o dejar una tra- 
za con «baja lápiz» que con «pen- 
do wn». 

No vamos a contar todo aquello que 
afecta al LOGO de una manera gene- 
ral, entre otras cosas porque en el nú- 
mero 1 de esta misma revista se publi- 
có el artículo LOGO, LENGUAJE 
INTUITIVO donde el lector hallará 
una excelente introducción y una pre- 
sentación general de este interesante 
lenguaje. Nos centraremos exclusiva- 
mente en aquellos aspectos del LOGO 



MSX español que consideremos de 
mayor interés inmediato. 

Antes de continuar conviene aclarar 
algunos aspectos para evitar malen- 
tendidos. Al LOGO se le asocia gene- 
ralmente a las tortugas, a los gráficos, 
a los niños, y a la ausencia de conoci- 
mientos de programación. Es verdad, 
pero no toda la verdad. Evidentemen- 
te es un lenguaje tremendamente ló- 
gico, podríamos decir que uno de los 
más «humanos» de entre los lenguajes 
existentes, gracias al cual se puede 
acometer la tarea de controlar un or- 
denador para hacer ciertas funciones 
con un mínimo de conocimientos y de 
esfuerzo... hasta los niños pueden ha- 
cerlo. Ciertamente, para un niño re- 
sulta tan fácil hacer dibujos sencillos, 
jugar con colores o hacer algunas 
cuentas con ordenador que con papel, 
lápiz, goma de borrar y pinturas de co- 
lores. Pero también hay que admitir 
que cuando se trata de hacer algo más 
sofisticado, la candidez del sistema va 
desapareciendo. Con todo, el LOGO 
es un lenguaje altamente formativo 
para todas aquellas personas, educa- 
dores, investigadores, etc. que de una 



u otra forma deban utilizar el ordena- 
dor como complemento o sustitución 
de actividades humanas como pueden 
ser la robótica, inteligencia artificial, 
o simplemente como mentalización in- 
formática. 



LAS TORTUGAS Y SUS FORMAS 



En el horizonte del LOGO existen 
una serie de «mundos», de los cuales 
el de los gráficos es sin lugar a duda 
el más importante, y dentro de él, el 
«mundo de la tortuga». En el caso del 
LOGO MSX, y algún otro, debemos 
hablar mejor que de tortuga, de «co- 
modín» ya que ésta puede tomar la 
forma de un helicóptero, un perro, 
una pared de ladrillos o un cohete. 
Pueden utilizarse hasta 60 figuras o 
formas (0-59), de las cuales 34 están 
predefinidas al encender el equipo. 
Todas ellas pueden ser rediseñadas 
por el programador. 

La facilidad del MSX para manejar 
sprites se refleja también en el LOGO 
MSX. Se pueden controlar hasta 30 
tortugas u objetos diferentes (0-29). 
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El control se ejerce mediante la pri- 
mitiva «designa» seguida del número 
de una tortuga en concreto, una lista 
de números de tortugas o la primitiva 
«todo» para cubrir las 30 posibles tor- 
tugas a la vez. 

Resumiendo, podemos manejar a la 
vez de 1 a 30 tortugas u objetos, y para 
cada una podemos elegir de entre 60 
formas. Cada tortuga está siempre 
identificada por un «número de or- 
den» y un «número de forma». Por ra- 
zones históricas se sigue dando el 
nombre genérico de «tortuga» a cual- 
quiera de los posibles 30 objetos. Esto 
puede crear inicialmente alguna con- 
fusión. Por ejemplo, en el caso de que 
funcionemos con la tortuga con for- 
ma de gato (2) y la tortuga 4 con for- 
ma de auténtica tortuga (36) puede re- 
sultar confuso dar la orden de que 
avance la tortuga 20 pasos y en la 
pantalla se mantenga estática la única 
tortuga visible y por el contrario se 
desplace el gato... 

Por el momento, para no complicar 
las cosas, nos vamos a limitar a una 
sola tortuga, aunque, más adelante ju- 
garemos con varias a la vez. 

La forma de la tortuga se asigna me- 
diante la primitiva «ffigura<número 
(0 - 59)>». 

En un momento dado podemos sa- 
ber la forma correspondiente a la tor- 
tuga en curso mediante «figura». Con 
ayuda de «quien» podremos conocer 
con qué número de tortuga estamos 
operando. 

Con la primitiva «rg» hacemos una 
restauración de las tortugas a su esta- 
do inicial y con «vp» borramos el tex- 
to que hubiera en la pantalla. Con 
«es» (escribe) podemos reflejar en 
pantalla cualquier resultado. Se trata 
del equivalente a la instrucción 
PR1NT del BASIC. 

?ffigura 8 tortuga/ Locomoto 

ra 

?ffigura 4 t rotuga/cami on 
?ffigura 38 tortuga/tortuga 

gi rada 

?es figura 38 
?es quien 
?rg designa 2 
?es figura 36 
?es quien 2 




DISEÑANDO FORMAS DE 
TORTUGA 

Diseñar la forma de una nueva tor- 
tuga o rediseñar cualquiera de las exis- 
tentes resulta bastante simple con el 
Editor de Figuras del LOGO MSX. 
Recordemos que inicialmente las figu- 
ras de 10 a 35 están sin definir. 

La base de cualquier figura es un 
cuadrado compuesto a su vez de 16 X 
16 cuadrados o casillas elementales, 
que pueden dejarse vacías o rellenar- 
se de un color determinado (el mismo 
para todas). Podremos cambiar de co- 
lor posteriormente, mientras utiliza- 
mos la tortuga. 

Supongamos que deseamos hacer 
una «cara sonriente» para utilizarla 
posteriormente en un programa y que- 
remos asignarle el número 12. En pri- 
mer lugar limpiaremos la pantalla 
«vp» y a continuación entraremos en 
el editor de figuras mediante «edfi 
12». Si el número 12 corresponde a 
una figura aún no definida aparecerá 
en el centro de la pantalla un gran cua- 
drado macizo (con CLR HOME apa- 
recerá el reticulado de 16 x 16). En 



caso contrario aparecerá la figura pre- 
definida. Si queremos que no aparez- 
ca la tortuga en curso en el centro po- 
demos eliminarla con «et», aún cuan- 
do no afectará nuestro diseño en caso 
de que decidamos dejarla donde está. 

Con ayuda de las cuatro teclas de 
dirección podemos situar el cursor 
parpadeante donde nos interese y me- 
diante la barra espaciadora consegui- 
remos que la casilla correspondiente 
se llene de color o se vacíe. 

Si consideramos que la «cara son- 
riente» está a nuestro gusto pulsare- 
mos ESC y habremos aumentado 
nuestro catálogo de formas de tortu- 
gas. Si no nos gusta podemos retocar- 
la mediante el procedimiento descrito 
o incluso borrarla entera para comen- 
zar de nuevo (CTRL-K ó CLS/HO- 
ME). 

Si lo que realmente queremos es 
abandonar la idea, sin que quede ras- 
tro de nuestro intento, CTRL-STOP 
lo hará por nosotros. 

Tal vez nos hayamos metido a mo- 
dificar una figura ya existnte pero al fi- 
nal no nos gusta lo que hemos hecho, 
por aquello de más vale lo malo cono- 
cido... Tampoco tenemos por qué 
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preocuparnos, CTRL-Y nos restaura 
la figura inicial de la tortuga. 

Si queremos hacer criaturas clónicas 
o duplicadas, podemos ayudarnos de 
la primitiva «copiafi <número de la fi- 
guraXnúmero nueva figura>». Esto 
puede resultar útil en nuestro caso si 
queremos aprovechar la «cara son- 
riente» número 12 para confeccionar 
una «cara triste» como número 14. 
Para ello lo primero que tenemos que 
hacer es copiar la cara sonriente asig- 
nándola a la figura 14. Después pasa- 
remos a editar. Todo esto se consigue 
con las siguientes líneas: 

?ffigura 12 cara sonriente 
?ffigura 14 cuadro en blanco 
?copiafi 12 14 
?ffigura 14 cara sonriente 
?edfi 14 para modificar 
La figura 

Si apagamos el ordenador o tene- 
mos que hacer un RESET perderemos 
todo el trabajo si no hemos tenido la 
precaución de archivarlo en cassette o 
disco (guardac <nombre> ó guarda 
<nombre> respectivamente). 

Como ejercicio podemos visualizar 
una a una, de una manera automáti- 
ca, las 60 formas de las tortugas que 
tenemos programadas en un momen- 
to dado. Basta con que tecleemos: 



?vp rg 

ffigura fcursor CIO 12] es 
figura espera 50 
repite 59 

Cffigura figura + 1 fcursor 
C10 12] es figura espera 50 
vp r g ] 

La composición, byte a byte, de una 
figura se obtiene con «obfi <núme- 
ro>». Los 32 valores obtenidos se co- 
rresponden con la siguiente distribu- 
ción: byte superior de la mitad izquier- 
da del sprite, byte inferior de la 
parte izquierda, byte superior de la 
parte derecha,..., byte inferior de la 
parte derecha. 

En el caso de la cara sonriente nú- 
mero 12 la composición es la siguien- 
te (obtenida con «es obfi 12»): 



DIBUJO CON LA TORTUGA 

Se supone que todas las tortugas lle- 
van debajo de su caparazón un lapice- 
ro que pueden bajar («bl») para pin- 
tar cuando se mueven o levantar 
(«al») para no marcar durante el des- 
plazamiento. También van provistas 
de una goma que utilizan para borrar 
(«gl») los trazos que encuentran al pa- 
sar, cuando conviene. 

El desplazamiento de las tortugas 
puede hacerse avanzando («av») o re- 



fi La 


decimal 


binario 




graf i co 


01 


015 


240 


0000111111110000 




******** 


02 


016 


008 


0001000000001000 




* * 


03 


032 


004 


0010000000000100 




* * 


04 


064 


002 


0100000000000010 


* 


* 


05 


134 


097 


1000011001100001 


* 


** ** * 


06 


134 


097 


1000011001100001 


* 


** ** * 


07 


128 


001 


1000000000000001 




* 


08 


129 


129 


1000000110000001 


* 


** * 


09 


129 


129 


1000000110000001 


* 


** * 


10 


128 


001 


1000000000000001 


★ 


* 


11 


136 


017 


1000100000010001 




* * * 


12 


132 


033 


1000010000100001 


* 


* * * 


13 


067 


194 


0100001001000010 


★ 


* * * 


14 


032 


004 


0010000110000100 




* ** * 


15 


016 


008 


0001 000000001000 




* * 


16 


015 


240 


0000111111110000 




******** 



trocediendo («re») un número cual- 
quiera de pasos, o girando a la dere- 
cha («de») o izquierda («iz») un nú- 
mero de grados estipulado. Mediante 
«centro» podemos hacer que en un de- 
terminado momento la tortuga deje de 
hacer lo que está haciendo y vuelva «a 
casa» (posición central de la pantalla). 

También puede fijarse el rumbo 
(0-360 grados) mediante «frumbo 
<grados>» o conocerse éste median- 
te «rumbo». 

Las siguientes líneas son un ejem- 
plo de todo esto: 



?rg vp al av 50 avanzar 50 
?de 90 av 50 



?cent ro 



?frumbo 45 
av 80 

?centro repite 



pasos 

girar derecha 
y avanzar 50 
retorna tor- 
tuga a posi- 
ción inicial 
80 pasos en 
dirección ñor 
oeste 

restaura tor- 
15 Cal av 2 bl tuga y traza 
av 2 espera 10 lineas dis 
20] continuas 

La tortuga podemos hacerla apare- 
cer («mt») o desaparecer («et»). En el 
caso anterior podíamos haber conse- 
guido el trazado discontinuo sin que 
se viera la tortuga, añadiendo «et» 
después de «centro». 

La primitiva «limpia» elimina los 
gráficos que haya en la pantalla pero 
sin afectar a las tortugas. 

Por lo que respecta al color pode- 
mos elegirlo libremente tanto para la 
tortuga («fet») como para el lapicero 
(«fcl») o el fondo de pantalla («ffo»). 
Las primitivas «color», «el» y «fondo» 
nos informan respectivamente de los 
colores de la tortuga, lapicero y fondo 
que estamos utilizando. 

El color (transparente) hace desa- 
parecer lo que se pinte con él. Los 
quince colores que pueden utilizarse 
(1-15) son respectivamente: negro, 
verde medio, verde claro, azul oscu- 
ro, azul claro, rojo oscuro, lila, rojo 
medio, rojo claro, amarillo, amarillo 
claro, verde oscuro, magenta, gris y 
blanco. 

Supongamos que gracias al lapicero 
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The Gruneberg Linkword Language System es un sistema, para enseñanza de idiomas, más 
fácil que los métodos convencionales aplicados actualmente. 
En poco tiempo, máximo 20 horas, te enseñará un vocabulario de 400 palabras y adquirirás unas buenas 
nociones de gramática. Esto te permitirá entender y ser entendido en tus viajes a lugares de habla inglesa 
o en tus contactos con personas que se expresen en ese idioma. 

Por otra parte, el Sistema PlusData, consigue que el ordenador se convierta en un perfecto profesor que 
te explicará, orientará y corregirá, manteniendo en todo momento un "diálogo" interactivo de resulta- 
dos sorprendentes. 




THE GRUNEBERG LINKWORD 
LANGUAGE SYSTEM 

u/doto 



pi 




i Tavlor. "POPULAR 

Computer world--. 



-"PERSONAL COMPUTER 
WORLD": 

"Un suceso fuera de serie..." 



¿h'Ó?ce" " c °mputer 

interesante.. " el mas 



Software 
educativo 



edad: 8 a99 
a n o s 




Programas de EAO para EGB. 
Cursos de Basic, Cobol, etc. AUTODIDACTAS. 




Nombre 

Apellidos 

Dirección 

Población 

D.P 

Forma de pago: 



Reembolso [ 



.Tino 

Giro postal □ 



Envío talón [ 



□ Curso de Inglés 1.' parte. 10 lecciones Linkword. (Cinta) P.V.P. 6.900.-Ptas. 

□ Curso de Inglés 1. a parte. 10 lecciones Linkword. (3,5"-Disk) P.V.P. 7.900.-Ptas. 

ENVIAR ESTE CUPON A: PLUS DATA, S.A. C/. GRAN VIA, 661 pral. 08010-Barcelona. Tel. 246 02 02 
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de la tortuga hemos dibujado un trián- 
gulo, que a continuación queremos 
pintar del mismo color. Basta con que 
nos situemos en un punto cualquiera 
del triángulo y utilicemos «bl llena». 

Por último podemos dibujar un 
punto en la pantalla con «punto [x y]». 

Las tortugas pueden situarse en una 
determinada parte de la pantalla me- 
diante «fpos [x y]» donde X e Y son 
las coordenadas del lugar deseado. 
Pueden situarse en otra posición del 
eje X mediante «fijax X» o en el eje 
Y con «fijay Y» si sólo se pretende 
desplazarse según uno de los ejes. La 
posición de la tortuga puede conocer- 
se mediante «pos», «coorx» ó «coory» 
respectivamente . 

Además de la posibilidad de avan- 
zar paso a paso se puede hacer con 
gran facilidad que las figuras se des- 
placen a una cierta velocidad («fvel») 
e incluso ésta puede fijarse indepen- 
dientemente en sentido horizontal 
(«fvelx») o vertical («fvely»). Los co- 
rrespondientes valores pueden cono- 
cerse mediante «vel», «velx» y «vely». 



MANEJO DIRECTO DE 
COMANDOS 



Lo dejaremos enteramente a crite- 
rio del lector, de acuerdo con su ta- 
lento creativo, pero sugeriremos ir 
probando uno a uno todos aquellos 
comandos o primitivas tales como 
avanzar, retroceder, cambiar colores, 
borrar, posicionar, girar etc. Si no te- 
nemos a mano el manual podemos re- 
cordar la lista de las primitivas me- 
diante «primitivas» (STOP para parar 
y cualquier tecla para seguir). Teclea 
el siguiente ejemplo: 

?fpos C-10 -10: 

?bl ffigura 5 av 20 

?fcl 8 de 30 av 30 re 10 de 

45 av 30 
?et iz 90 av 15 
?mt aL av 10 ffo 5 fct 15 



PROCEDIMIENTOS 



Mediante comandos directos, uno a 
uno, podemos hacer muchas cosas, 



pero con gran lentitud y esfuerzo, so- 
bre todo cuando existen procesos re- 
petitivos. 

Con lo que hemos visto hasta ahora 
podríamos hacer un programa para di- 
bujar una casa. Lo malo es que si qui- 
siéramos hacer otra distinta debería- 
mos partir también de cero, aunque 
utilicemos elementos comunes. Es fá- 
cil de imaginar que si tuviéramos pro- 
cedimientos para dibujar ventanas, 
puertas o tejados, programar el dise- 
ño de una casa sería, como utilizar pie- 
zas de un «mecano». 

«Procedimientos» en LOGO, son 
programas auxiliares o «recetas» para 
efectuar funciones concretas (gráficos, 
manejo de tortugas, procesos mate- 
máticos, musicales, etc.). Una vez ge- 
nerados, los «procedimientos» pueden 
utilizarse tantas veces como se quiera, 
incluso en forma recursiva. La mecá- 
nica para generar procedimientos es 
como sigue: 

?para <nombre>[ :var1 :var2 1 



Lista de comandos 



fin 

Para ejecutar un procedimiento 
basta llamarle por su nombre, seguido 
de las variables correspondientes (si se 
utilizan). Más adelante veremos una 
serie de ejemplos. 

Para conocer los «procedimientos» 
existentes en memoria podemos utili- 
zar «imts». Si deseamos eliminar uno 
en especial utilizaremos «bo- 
rra»<nombre> pero si lo que desea- 
mos es ver su composición y quizá mo- 
dificarlo deberemos emplear «edi- 
ta»<nombre>. 



ESPIRALES Y FIGURAS 
GIRATORIAS 



A. 

?para espiraL :paso :anguLo 
av :paso 
de :anguLo 

espiraL :paso+2 ranguLo 
fin 

Acabamos de generar un procedi- 
miento con dos variables (paso y án- 



gulo). Aunque no hemos manejado 
aún los procedimientos no creemos 
que éste resulte difícil de comprender, 
y además resulta muy ilustrativo. 

Previa limpieza de pantalla pode- 
mos probar diversos valores de «paso» 
y «ángulo» hasta conseguir figuras in- 
teresantes. Prueba por ejemplo: 

B. 

?para cuadrado 
bL et 

repite 4Cav 30 de 9011 
fin 

?repite 8Ccuadrado de 45] 

Genera un cuadrado giratorio alre- 
dedor del punto central de la pantalla. 
Prueba otros valores y añade color. 

C. 

?para rectanguLo 
bL et 

av 30 de 90 
av 50 de 90 
av 30 de 90 
av 50 
fin 

?repite 1 5 CrectanguLo de 15H 

Igual que B pero utilizando rectán- 
gulos 



MOVIMIENTO 



D. 

?para via 

fijax -120 

et de 90 

bL av 240 

fijay -2 

re 240 

fin 
?para tren 

rg vp via 

fijay 3 

ffigura 8 mt aL 
fveLx 3 
fin 
?tren 

Este sencilo listado dibuja una vía y 
hace que circule una máquina de iz- 
quierda a derecha a una cierta veloci- 
dad (3). Probar otras velocidades y 
otras figuras, por ejemplo la número 
3. 
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PINTURA DE SUPERFICIES 



?para colores 

rg vp cuadrado 

f rumbo 45 

et al et av 10 bl 

repite 14 Cfcl cL-1 Llena 

espera 302 

fin 
?colores 

Estas líneas trazan un cuadrado (el 
diseñado para el ejercicio A) y lo van 
llenando de diversos colores. 

LAS MATEMATICAS Y EL LOGO 
MSX 

Aunque el LOGO no es un lengua- 
je pensado para cálculos matemáticos 
complicados, sí nos permite manejar 
con gran facilidad una serie de coman- 
dos básicos como son las cuatro reglas 
(«suma»< A B >, «dif»< A B >, 
«producto» < A B >, «cociente»< A 
B >), funciones trigonométricas (sen, 
eos, arctan), raíz cuadrada («re») y 
una serie de funciones útiles como son 
el redondeo («redondea»), parte ente- 
ra («ent»), generación de números 
aleatorios («azar») y operaciones lógi- 
cas. Por ejemplo: 



operación 

?es ent 45,6 
?es re 45,6 
?es suma 7 3 
?es seno 30 
?es re 47+32*3 
?es 27<3 



resu It ado 
45 

6,757772 

10 

0,5 

11,95826 
falso 



Algunas de las operaciones pode- 
mos escribirlas de una forma más ha- 
bitual como por ejemplo: 



?es 47*3 
?es 12+3-18 



141 
-3 



TORTUGAS MULTIPLES Y 
FIGURAS ANIMADAS 



Las diversas tortugas puede mane- 
jarse una a una o un grupo a la vez. 




Para ello, antes de dar las instruccio- 
nes pertinentes debemos poner «a la 
escucha» la tortuga o tortugas de que 
se trate mediante «designa»<número 
de tortuga> o [lista de tortugas]. 
Aquellas tortugas que estén realizan- 
do alguna actividad no se ven afecta- 
das por las instrucciones que se den a 
las restantes. 

Como ejemplo indicamos un proce- 
so muy elemental para hacer que tres 
tortugas tengan un movimiento uni- 
forme y simultáneo de izquierda a de- 
recha. Dejamos al lector que lo modi- 
fique para imprimir a cada objeto una 
velocidad distinta, que comiencen des- 
de lugares diferentes, etc. 

?para carrera 
rg vp 

designa ffigura 3 al 
fposC-120 30] mt 
designa 1 ffigura 4 al 



fposC-120 ] mt 
designa 2 ffigura 7 al 
fposC-120 -30] mt 
desinga C0 1 21 fvelx 10 
fin 

Para comenzar la carrera se teclea 
«carrera RETURN». Si durante este 
proceso deseamos que aparezca en es- 
cena un cohete que se desplace verti- 
calmente en el centro de la pantalla 
basta con teclear lo siguiente: 

?designa 4 ffigura 5 mt 
fvel 3 

Tal vez nos interese detectar la co- 
lisión del cohete y el helicóptero y 
montar algún efecto especial. Con 
LOGO MSX español disponemos de 
«demonios» o «vigilantes» que nos 
avisan cuando se produce una colisión 
entre dos objetos determinados y a los 
cuales podemos dar una lista de ins- 
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trucciones a ejecutar cuando esto ocu- 
rra («en.contacto»<tortuga x> <tor- 
tuga y> [lista de instrucciones] 

Estos vigilantes pueden aprovechar- 
se también para detectar ciertas accio- 
nes como puede ser la actuación de un 
disparador de joystick («cuando»). 

La acción de los vigilantes o demo- 
nios se cancela mediante «bods» (bo- 
rra demonios). 

Otro efecto interesante es la anima- 



ción de figuras (vuelo de pájaro, ca- 
rrera de un perro, etc.). Para ello pue- 
de asignarse en una secuencia y caden- 
cia determinadas varias formas a una 
misma tortuga (por ejemplo diversar 
posturas del cuerpo en la carrera), 
completarse con movimientos inde- 
pendientes de otras tortugas (coches 
que pasan, objetos que aparecen, etc) 
y tal vez acompañarse de combinacio- 
nes de color y sonido. 



Evidentemente no tenemos espacio 
para tocar todos los aspectos del 
LOGO, pero esperamos haber conse- 
guido interesar a alguno de nuestros 
lectores lo suficiente como para justif- 
carles trabajar pacientemente el orde- 
nador con ayuda del manual de ins- 
trucciones y llegar a dominar este len- 
guaje de programación que se está ha- 
ciendo tan popular, fundamentalmen- 
te en el campo de la enseñanza. 



¿1 ZOCO D£ tNPUT 



Todo se compra y se vende. Los antiguos zocos fueron lugares destinados a 
todo tipo de transacciones. tNPUT también tiene el suyo. Vuestras operaciones 
de compra, cambio o venta serán publicadas en esta sección, pero dos son las 
limitaciones que imponemos: 

a) La propuesta tendrá que ver con la microinformática. 

b) Nos reservamos el derecho de no publicar aquellos insertos de los que se 
sospeche un trasfondo lucrativo. 

Ahora un ruego. Tratar de resumir al máximo el texto: escribir casi como un 
telegrama siendo claros y concisos. 

Envía tu mensaje a: 

INPUTMSXZOCO 

P.° de la Castellana, 93. Planta 14 
28046 MADRID 




¡NO TE PIERDAS NI UN SOLO EJEMPLAR! 



INPUT MSX quiere proporcionar 
a sus lectores este nuevo servicio de 
ejemplares atrasados para que no pierdan la 
oportunidad de tener en sus hogares todos 
los ejemplares de esta revista, líder en el 
mercado español. 

Podréis solicitar cualquier número de 



INPUT MSX que queráis, siempre al precio 
de cubierta (sin más gastos). 

Utiliza el cupón adjunto, enviándolo a 
EDISA (Dpto. de Suscripciones), López de 
Hoyos, 141 - 28002 Madrid, o bien llámanos 
por teléfono al ( 9 1 ) 4 1 5 97 12. 






CUPON DE PEDIDO 



SI, envíenme contrarreembolso 
MSX de los números: 

(marca con una (X) tu elección) 

00000 



ejemplares de INPUT 



NOMBRE iiiiii 



J_J L 



J i I I I l I i I I I ! 1 ! I i i i 



APELLIDOS l_J i i i i i i i i i i i i i ■ i i i i i i i i i i i i i i 

DOMICILIO i i l l i i l i i i t i I i i i i i i i i i 



_L_I 



NUM. lili PISO 
POBLACION l 




J lililí 



i ESCALERA i | i COD. POSTAL i i i i i i 

i I i i i i i l i l i i i i ' PROV i i l i i I i i i i i i 

L_l—1_ J FIRMA 



'A 




UN PROGRAMA 
QUE APRENDE 




Con este artículo, vamos a tratar de 
introduciros en el apasionante mundo 
de la Inteligencia Artificial, prescin- 
diendo de las largas y aburridas parra- 
fadas teóricas habituales en este tipo de 
trabajos. 

Para que ello sea posible, debemos 
dar por supuestos algunos principios 
muy básicos que, a pesar de su senci- 
llez, es posible que algún lector no co- 
nozca. A los que se encuentren en ese 
caso, les remitimos al manual de uso 
de su «micro», o a cualquier libro so- 
bre programación en BASIC MSX. 

En cuanto a aquellos que disfruten 
de un nivel más avanzado, les invita- 
mos a olvidarse del texto de este artí- 
culo y a centrarse en el estudio del 
programa que lo acompaña el «pro- 
grama inteligente» que hemos llama- 
do Sabelotodo. 

A pesar de estar escrito en BASIC, 
muestra lo que la Inteligencia Artifi- 
cial puede llegar a hacer a través de 
un breve puñado de instrucciones. 
Otra ventaja, además de su corto lis- 
tado, es que está pensado para que el 
lector lo modifique según sus necesi- 
dades o aficiones. 



SABELOTODO 



Se trata de un curioso ejemplo de 
aplicación de la Inteligencia Artificial 

que burla las limitaciones del BASIC 
e inaugura una serie de programas si- 
milares que irán apareciendo dentro 
de esta sección en los próximos núme- 
ros. 

El Sabelotodo se basa en un sistema 
matricial de tablas de propiedades con 
recursividad. que permite memorizar 
datos y tratarlos deductivamente para 
«aprender». Es decir, un programa 
¡que aprende! 

Lo hemos hecho de forma que lo 
que aprenda sea Historia, pero es sus- 



ceptible de ser modificado, con unos 
pocos retoques, para trabajar de la 
misma manera con otros temas, como 
Deportes. Records, etc. 

A continuación pasamos a ver dete- 
nidamente qué es lo que hace, para 
describir despúes cómo lo hace: 

1".- Pensamos un personaje históri- 
co cualquiera, del que conozcamos al- 
gunas características, comenzamos a 
jugar. 

2°.- El programa, que ha de adivi- 
nar el nombre del personaje, nos pre- 
gunta si posee una característica con- 
creta (alguna que ya tenga en su me- 
moria), y así sucesivamente hasta de- 
ducir, por eliminación, cuál es el per- 
sonaje que habíamos pensado. 

3 o .- Si el programa no tiene almace- 
nado previamente (si el programa no 
ha «aprendido» previamente) el nom- 
bre y las características del personaje, 
se da por vencido, nos pide su nom- 
bre, y nos pregunta más cosas sobre él 
para ampliar sus conocimientos. 

4".- De esta forma, partiendo de un 
solo personaje almacenado en la me- 
moria, puede llegar a conocer un sin- 
número de personajes, hasta llenar to- 
talmente la memoria. 

El programa está estructurado con 
mucha claridad y acompañado de las 
oportunas sentencias REM, pués su 
misión es precisamente la de serviros 
como material de trabajo para que 
aprendáis a hacer vuestros propios 
programas de Inteligencia Artificial. 

Ahora que sabemos qué es lo que 
hace, vamos a ver el cómo: 

l .- El programa toma la primera 
característica del primer personaje al- 
macenado en la memoria y pregunta 
si nuestro personaje la posee. 

2".- Si la respuesta es negativa, co- 
loca el valor «cero» a todos los perso- 
najes que posean esa característica y 
pasa al siguiente que tenga todavía el 
valor «uno». 

3°.- Si es positiva, coloca el valor 



«cero» a todos los personajes que no 
la posean y pasa a la siguiente carac- 
terística del primer personaje. 

4".- Sigue con el proceso anterior 
hasta que todos los personajes que co- 
noce tengan el valor «cero», en cuyo 
caso se da por vencido, o hasta que en- 
cuentre uno que cumpla todas las con- 
diciones, es decir, que hayamos res- 
pondido afirmativamente a todas sus 
características. 

5".- Si el personaje propuesto por el 
ordenador no es el que habíamos pen- 
sado (a pesar de que hubieran coinci- 
dido todas las características), o si el 
ordenador se da por vencido, nos pide 
el nombre del personaje y almacena 
bajo él todas las características dedu- 
cidas de las preguntas y respuestas an- 
teriores, más las que introduzcamos 
directamente cuando nos pida más da- 
tos. 

Por si esta descripción pudiera pa- 
recer demasiado enrevesada, de hecho 
lo es. vamos a verlo otra vez con un 
ejemplo práctico. Supongamos que el 



26 INPUT 




programa ya tiene almacenados en la 
memoria los nombres de cuatro insig- 
nes personajes históricos con sus co- 
rrespondientes características, y que 
nosotros nos disponemos a jugar con 
él para que trate de adivinar un nue- 
vo personaje que se nos ocurra. En 
este momento, las tablas de propieda- 
des del programa muestran los si- 
guientes datos: 

CERVANTES 
fué literato 
escribió El Quijote 
luchó en Lepanto 
era manco 

NAPOLEON 
fué emperador 
conquistó Europa 
venció en Jena 
fué desterrado 

GOYA 
fué pintor 
trabajó en la corte 



murió en 1828 
era aragonés 

KANT 
fué filósofo 
era prusiano 
nació en 1724 
renovó la filosofía 

Nosotros pensamos un personaje 
cualquiera, un pintor, por ejemplo: 
Velázquez. 

El ordenador comienza por pregun- 
tarnos: ¿Fué literato? (primera carac- 
terística del primer personaje). Con- 
testamos que no. A continuación el 
programa busca a todos los persona- 
jes que cumplan esa condición (de los 
cuatro, sólo la cumple Cervantes) y les 
coloca un «cero». El siguiente perso- 
naje que aún no ha sido eliminado es 
Napoleón. Por tanto, nos pregunta 
¿Fué emperador? La respuesta es no, 
y el ordenador procede de la misma 
manera. El siguiente es Goya. El pro- 
grama nos pregunta ¿Fué pintor? 



Contestamos que si, con lo que se co- 
loca un «cero» para Kant, que no cum- 
ple esa condición. Ya sólo nos queda 
Goya. La pregunta siguiente es ¿Tra- 
bajó en la corte? Como Velázquez 
también pintó en la corte, contesta- 
mos que sí. Después preguntará ¿Mu- 
rió en 1828? A lo que responderemos 
negativamente. El programa coloca 
un «cero» a Goya y. como ya no que- 
dan más personajes, se da por venci- 
do y nos dice: 

«No lo conozco. ¿Quién es?» 

Introducimos su nombre (VELAZ- 
QUEZ), y a continuación nos pide 
que le digamos más cosas sobre él. In- 
troducimos dos características más: 

«Nació en Sevilla» y «Murió en Ma- 
drid» 

Finalmente la tabla de propiedad de 
Velázquez queda así: 

VELAZQUEZ 
fué pintor 
trabajó en la corte 
nació en Sevilla 
murió en Madrid 

Las características a las que había- 
mos contestado afirmativamente («fué 
pintor» y «trabajó en la corte») se ha- 
bían almacenado previamente en el lu- 
gar que iba a ocupar en la matriz el 
nuevo personaje. Antes de hacer cada 
pregunta, el programa consultaba esta 
lista de propiedades nueva para no re- 
petir una pregunta ya formulada. Si al 
final hubiera resultado que el perso- 
naje sí era conocido por la máquina 
(por ejemplo, si hubiéramos pensado 
en Goya), esta nueva lista se hubiera 
borrado, pues no se trataría de un per- 
sonaje nuevo. 



DESGLOSADO 



Cuando ejecutéis el programa, ob- 
servaréis que hace lo mínimo necesa- 
rio para cumplir con su cometido, y 
que no pierde el tiempo en adornos ni 
virtuosismos. Esto es así porque lo he- 
mos hecho eliminando todos los ele- 
mentos superfluos (exceptuando, na- 
turalmente, las sentencias REM), y 
organizando el listado todo lo que ha 
sido posible, para que no haya ningu- 
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1/0 



NOMBRE 



MID$(A$(1),2,20) 



VALOR 



MID$(A$(1),22,20) 



a$(2; 
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DISPOSICION DE LOS DATOS DE LA MATRIZ A$ (50) 



na dificultad en localizar, analizar y 
(éste es nuestro mayor deseo) modifi- 
car las rutinas. 

Hasta ahora hemos utilizado la pa- 
labra «característica» para referirnos a 
los elementos que caracterizan a los 
personajes. Desde el punto de vista de 
nuestra semántica, esto es correcto, 
pero en el argot de la Inteligencia Ar- 
tificial no lo es. A partir de ahora nos 
referiremos a ese concepto llamándo- 
le «valor». 

Aquellos que no estén familiariza- 
dos con el tratamiento de matrices al- 
fanuméricas encontrarán las explica- 
ciones que vienen a continuación qui- 
zás demasiado complicadas. Si es así, 
recomendamos que se salten esa par- 
te y practiquen un poco haciendo uso 
del manual. No es difícil de aprender. 

La base de datos del programa se 
fundamenta en una matriz bidimensio- 
nal de tipo alfanumérico (concreta- 
mente A$(50)), que hemos dividido 
maginariamente de veinte en veinte 
:aracteres por línea a fin de delimitar 
2l espacio disponible para cada valor. 
Por esta razón, el programa no admi- 
te cadenas de más de veinte caracte- 
res. Para hacerlo más gráfico, nos re- 
mitiremos a la figura 1. Cada línea de 
la matriz, A$(l) por ejemplo, consta 
de diez espacios imaginarios, más un 
espacio de un sólo carácter para indi- 
car si el personaje en cuestión ha sido 
ya descartado o no (0/1). En el primer 
espacio se coloca el nombre, y en los 
nueve siguientes sus valores corres- 



pondientes, de forma que a cada per- 
sonaje le corresponde una línea de la 
matriz. 

Dicho esto, la primera sugerencia 
que se nos ocurre es ampliar la capa- 
cidad de la matriz para dar cabida a 
más personajes y/o más valores. 

En cuanto al listado del programa, 
las sentencias REM ya indican clara- 
mente dónde empiezan y acaban las 
rutinas y cuál es su función. De todas 
formas, vamos a desglosarlas somera- 
mente. 

La rutina 1000-1050 es la encargada 
de ordenar y repartir el trabajo a las 
demás. Procesa nuestras respuestas y 
envía el flujo del programa a la rutina 
1100-1180 ó a la 1300-1360 según sea 
nuestra respuesta positiva o negativa 
respectivamente. Apréciese que am- 
bas rutinas comparten la línea 1162 y 
siguientes (se ha hecho así para aho- 
rrar memoria y acortar el listado). 

El resto de las rutinas son las encar- 
gadas de introducir nuevos datos des- 
pués de «darse por vencida» la máqui- 
na, salvar y cargar datos, pasar a un 
nuevo personaje, etc. Será misión del 
lector «desmenuzar» el programa lí- 
nea por línea para llegar hasta el fon- 
do de todas las rutinas e introducir las 
modificaciones que crea oportunas. 



FUNCIONAMIENTO 

Antes de "que comencéis a teclear el 
programa, debemos advertir que sólo 



puede funcionar correctamente si el 
cursor está en modo para mayúsculas 
(Caps Lock), pues de lo contrario no 
reconocería la tecla pulsada en algu- 
nas sentencias condicionales. Natural- 
mente, esto podría remediarse fácil- 
mente. Dejaremos que sea el lector 
quien lo haga. 

Al comenzar, el programa almace- 
na en memoria un sólo personaje 
(Cervantes), con unos cuantos valo- 
res: 

- Nació en el siglo XVI 

- Murió en el siglo XVII 

- Escribió El Quijote 

- Estuvo en Lepanto 

- Fra manco 

Esto debemos tenerlo en cuenta 
cuando juguemos por primera vez. A 
medida que vayamos usando el pro- 
grama, éste aprenderá muchos más 
personajes y sus correspondientes ca- 
racterísticas (valores). Si no queremos 
perder los datos almacenados al apa- 
gar el ordenador, cuando el programa 
nos pregunte si queremos pasar a otro 
personaje, podremos acceder a las ru- 
tinas de carga y grabado pulsando 
«N». Si no podemos esperar a que el 
programa nos haga esa pregunta (la 
hace cuando hemos terminado con un 
personaje), podemos interrumpir el 
programa pulsando BREAK y ha- 
cer: 

SAVE «CAS:SAB» 
Cuando el programa nos haga una 
pregunta, basta con pulsar «S» para 
contestar afirmativamente, y «N» para 
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hacerlo negativamente. Si el programa 
no identifica el personaje que le pro- 
ponemos, preguntará «No lo conozco. 
¿Quién es?». En este caso teclearemos 
su nombre (no más de veinte caracte- 
res), y después de que nos diga «Dime 
más sobre él», teclearemos sus carac- 
terísticas (hasta nueve) una por una, 
seguidas de ENTER . Cuando haya- 
mos terminado con ellas, teclearemos 
FIN. 

No nos cansaremos de decir que se 
trata de un programa abierto a vues- 
tras manipulaciones. Si podéis intro- 
ducir alguna mejora (seguro que sí), 
no dejéis de hacerlo. 

En próximos números volveremos 
con otros interesantes programas LA., 
hasta entonces, esperamos que paséis 
muy buenos ratos con el Sabelotodo. 

10 REM SABELOTODO 

20 REM COPY E. DEL VAl L E 

/ INPUT 
40 ri_S: LOC/^E 12,10 
50 PRINT "SABELOTODO": 

LOCATE 12,12 
60 PR 1NT '"¡fJPl-r MSX": 

LOCATE 1,22 
70 PRINT "PULSA UNA TECLA" 
80 K$=1NKEY$ 

90 1F K$="" THEN ÜCTC 80 
100 REM COMIENZO 
120 CLS: PRINT "ESTOY LISTO" 
130 PRINT "COMENZAR 

1": PRINT 'SALVAR/ CARGAR . 

2" 

140 X^VAL ONKEYS) 
150 IF X=C THEN GCTC 140 
160 0N X GOTO 9000,1750 
1000 REM. SELECTOR 
1C05 N$=MID$ÍA$(X),Y,20) : I F 
N$=" 

" AND R="1 THEN 191C:*N$- 
20 ESPACIOS 

1006 1F N$=" 

" AND P^0 TREN 1160 

1007 K=INSTP(A$(L) ,NÍ) 

1008 IF KO0 Ti- EN 1160 

1010 CLS: PRINT "PERSONAJE "; 

L-1 : LOCATE 0,21 : PRINT 

N$;"?" 
1020 K'i^INKEYS 
1030 IF KS='S" THEN 1105 
1040 IF KS="" THEN 1020 
1050 GOTO 1305 



1100 REM LO ES 
1105 R=1 

1110 FOR N=X T0 L-1 

1 1 20 IF INSTR(A$(N),NS)=G 

THEÍJ MICS(A£(N) ,1 ,1 ) 

-"O" 
113C NEXT 

1140 AS(L)=A$(L)+N$: 
LL=LL+2C 

1160 Y^Y+20: IF Y<183 
TH EN 1005 

1161 IF Y>183 AND k=1 
THEN 1910 

1162 Y=22 

1165 X=X+1 : IF X>=L AND 

R=C THEN 1800 
1170 IF MID$(A3>(X),1,1) = "0" 

THEN 1165 
1180 G0TC 1C00 
1300 REM NO 
1305 R=0 

1310 FOR N=> T0 L~1 

1320 IF INSTR(22,A$(N),Ni) 

<>0 THEN M1D$(A$(N) ,1 ,1) 

="0" 
1330 NEXT 
1360 G0TC 1162 
1400 REM LOAD 
1410 LOAD "CAS : SAB" 
1420 GCT0 1700 
1500 REM CTR0 
1530 LET T=0 

1540 CLS : L0CPTE 0,21: PRIM 
"DIME MAS SGBRF EL' 

1550 LINE INPUT U$ 

1555 IF l EN (US) GO- 
TEEN 1550 

1558 IF L EN fUi)<1 
THEN 1550 

1560 IF U$=' FIN" THEN 170C 

1570 Ai<L)=A$<L.)+ü$+StF:ING$ 
C(20-LEN(U$)),32) : 
LL=LL+20 

1575 IF LL>200 THEN 1700 

1580 CLS: LüCME 0,T: 
PRINT US 

1585 T = T+1 : LOCATE 0,21 
: PRINT 'DIME MAS 
S0CRE EL" 

1590 G0TC 1550 

1600 REM SPVE 

161 C SAVE "CAS:SAE" 

1620 GCTC 1700 

1700 REM FIN 

1702 L=L + 1 : LL=22: X=1 : Y=22 



1703 II- L>5C THEN CLS: PRINT 
"NO HAY MAS ME MORIA" : 
STOP 

1710 FOR N=1 10 L-1 : 

MID$(A$(N) ,1 ,1) = "1 " 
:NEXT 

1720 CLS: LOCATE 0,21 : 

PRINT "SEGUIMOS CON 
OTRO ?" 

1725 K $= I N K E Y 3> 

1730 IF K$^"" ThEN 1725 

1740 IF K$="N'' THEN 1750 

1745 GCTC 1000 

1750 LOCATE 0,21: PRINT'"PULSA 

1 PARA S AL VAR PULSA 

2 PARA CARGAR" 
1755 KS= 1NKE YS 

1760 IF K$="1 " THEN 1600 

1770 ] T Ki^"2'" THEN 140C 

1780 GCTC 1755 

1800 RE í" NO LO SE 

1810 CLS: LOCATE 0,20: F'klNT 

"NO LO CONO ¿ CC 

QUIEN ES ?":LJNH INPUT 

US 

1820 IF LEN CU$»2C TI EN 181C 
1830 I F LEN Cü$)<1 T HEN 1810 
1835 U$=" "+b$ 

1 840 AS»( L>=U$+STRIKGS( (2 1 -LEÍ. 

( USÓ ) ,32)+A$(L) : 

GOTO 1500 
1900 REM ES... 

1910 CLS : LOCATE 0,20: PRINT 
"ES ";M1D$(A?-(X) ,2,20) 
; "? " 

1915 K$=INK£Y¿ 

1920 IF KS-'V' THEN R=C : 
GCTC 1162 

1930 IF K$-"S" THEN 
GOTG '¡950 

1940 GCTC 1915 

1950 A$(L)="" 

1960 L^L-1 : GCTO 1700 

9000 PEM DATOS 

9010 CLEAR 1000C: DIM A$^50) 

9020 R=C:LL=22:L=?:X=1 : Y=22 

9030 RE AD FJ$: A$(1)=B$ 

9040 DPT A 1 MIGUEL DE CERCANTE 
S NACIO EN EL S.XVI MU 
RIO EN EL S.XVII ES CRIE 
10 EL QUIJOTE ESTUVO EN 
LEPANTC ERA MANCO 
ESTUVO ENCARCELADO 

9050 GOTO 1000 
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BUBCft TU nombre: 

UN CICLOMOTOR VEBPIND 

■»• ANTONIO FERNANDEZ DELBftDO, ALCALA DE HENARES (MADRID) . 
JUNA CADENA HIF'I DE BPjKCTKAW Z; DKO 
'■*»■ J LÍAN LOPEZ BALA, Al I CANTC ■ 

** EMILIO DE ANDRES DE LA VEGA, MADRID. 

J . LORENZO L.A6Ü SOLANA, R. DE O AMAR O O (CANTABRIA) . 

UN LP DE' GABINETE CALIBARI 

•M- SANTIAGO CAMPAYO "cÜÉbt" BADALONA (BARCELONA). 

*»■ ALBERTO VILARMAU ESPINAL < BARCEI ONA > . 

LUIS ALBERTO CARRIDN MORENO, VALLADOL I D . 
** MANUEL CASTILLEJOS VAYA, MADRID. 
«• MANUEL ALONSO MARTINEZ, BILBAO. 

•» REDRO BAR A MONA CORDERO , OOSLADA (MADRID) . 

MIBUEL BUNE RODRISUEZ. BARCELONA . 
** J OBECHU HERNANDEZ BAREA , SAN T URCE < VIZCAYA) . 

**■ ¿OSE LUIS MARTINEZ MUÑOZ, STA. COLOMA DE GRAMANET (BARCELONA) . 
GONZALO NOVOA SOTELO , ORENSE. 

UN LOTE DE SOFTWARE DE ERBE 

** SANTIAGO EBTe"anTa"baf"rTo, OETXO (VIZCAYA) . 

*• J - MANUEL COLOMINA MESTRES, STA. COLOMA DE GRAMANET (BARCELONA) 
M- VICTOF-eiNO RODRIGUEZ V A I — DESOSO , LEON. 
**- J . MANUEL RERE IRA SARCIA, BARCELONA. 
■M- MA. ANGUSTIAS DELGADO, GRANADA. 

■"• MANUEL TERRER MENA , CARTAGENA (MURCIA). 
+* MIGUEL SALAS GARCIA, MADRID. 

¿.CARLOS DE LA LLANA SANTO, REUS (TARRAGONA) . 
*» SERGIO MARTINEZ COLLDEPORN , BARCELONA. 
**■ ROBERTO TORRIJOG SANTOS , TALAYERA (TOLEDO) . 

TRES RROGRAMAS DE CDMPUI OG I CAL 



FERNANDO GONZALEZ RODRIGUEZ, LA OROTAYA (TENERIFE). 

J. ANTONIO ROZO GALL-ETERO, CHIVA (VALENCIA). 
** A. MANUEL YANEZ VALE I RO , BILBAO. 
**■ J ORD I MARZO VIDAL, BARC2ELONA. 

**■ JOAN CARRASCO DOMINBLJEZ, TERRASA (BARCELONA). 

ANSELMO FERNANDEZ BERODAB , MAL-AGA . 
**■ FRANCISCO MAC X A LACUSA , BARCELONA. 

■» ANDRE8 ORTIZ MENDEZ, MARTOREL (BARCELONA). 

•H- ESTEBAN HORCAJO ARROYO. S.S. DE LOS REYES (MADRID) . 
*» JAVIER BUBIRATS CERVERA , REUS (TARRAGONA) . 

TRES RROGRAMAS DE RROE I NBA 



JORDI PRUNEB CABTERAB, TERRASA (BARCELONA), 

•w- DAVID BRAVO CALVO, BARCELONA. 

** ANTONIO GRIMALT ANDREU , MANACOR (MALLORCA) . 

**' RUBEN DOMINGUEZ LO FE Z , AGU ADULE (ALMERIA) . 

*» SALVADOR DE LA FUENTE FERNANDEZ, VALENCIA. 

**■ ALFONSO MANTECON L.AGE , LAS ROZAS (MADRID) . 

•"■ MIGUEL LA TORRE ROV I ROBA , V I LAFRANCA DEL PENEDES (BARCELONA) 

** M. ANGEL F-LORES ACUNA, LA CORUNA. 

■» F. CARLOS GA I TAN AL-FARO. CORDOBA . 

**■ J. MIGUEL TORES CARO, CADIZ. 

TRES RROGRAMAS DE MICROUNO 

MANUEL F-INEIRO MBOADA • RORRINO (PONTEVEDRA) . 
A. J OSE RALACIOS SOLER, VALENCIA. 
SEBASTIAN MONZON PEREZ , SEVILLA. 
**■ J- CARLOS CAP' A FONO CUBERO, BITOEB (BARCELONA) . 

** JAVIER MINOJOSA RU I Z , CASTELLAR DEL VALLES (BARCELONA). 

ALFREDO CAN T EL X BUAREZ , OVIEDO (ASTURIAS) . 
**- R. ALBERTO BARBALLO CASCAN, BARCELONA. 
+*■ SANTIAGO FERRE I RO PARAMO, LA CORUNA. 
■» ANTONIO GALAN ELEZ, MADRID. 

JESUS VALERO ALCARAZ, MADRID. 

CUATRO RROGRAMAS DE BERMA 

*» ANTONIO GOMEZ. ABU I LAR*"™MALABA . 

«• FAOU I RODRIGUEZ GONZALEZ, BADAJOZ. 

*» FERNANDO ROJAS PALACIOS, ALGEC I RAS (CADIZ) . 

**■ RAFAEL ASEN J C) PLAZA , MARACENA (GRANADA). 

■*»• J- MANUEL RARRA BARBERO, LA HERRADURA (GRANADA) . 

RABI — O HERRERA PEREZ GRUESO , MORA (TOLEDO) . 

** TEOFILO DEL RINCON GONZALEZ, RU I G DEN VALS (IBIZA) . 

**■ JOSE LUIS GONZAL.EZ OLEA, FUENLABRADA (MADRID) . 

~ JAIME SOLA FL-OX, V I LANOVA I LA GELTRUB' (BARCELONA) . 

■H- Al — VARO DAPENA URGOLA , ZARAGOZA. 

UN K I T ROBOT ICO DE FERRE — MORET 

** JOSE JULIO VEL.AZOUEZ , LE JOÑA (VIZCAYA) . 
UN JOYSTIGK DE COMRULOQ I C AL 

** MIBUEL MILLAN DE LA TORRE, S.JUAN DEBP I (BARCELONA) . 
** VICENTE MORALEDA HIDALGO, SEVILLA. 

*>■ RAMON JUNGUERA SOBRON , SAI DA K ANO (VIZCAYA) . 

un joystick: DE MICROUNO 

» JOSE C. RODRIGUEZ ESCOBAR, MADRID. 
■» BENITO SANTAMARIA ROMERO , MADRID. 

** JOSE ANTONIO GONZALEZ CUETO, GIJON (ABTURI AS > . 

DANIEL ROSS E8TRABUEZ , BARCELONA. 
•» ANTONIO DIAZ GONZALEZ, SANTANDER. 

**■ EDUARDO TORRECILLAS VALVERDE , BADALONA (BARCELONA) . 
*♦ REDRO LANCILLA TELLA , ZARAGOZA. 

■h V. ANTONIO UCEDA ALVAREZ , BE TA FE (MADRID). 
** J. MANUEL VIGO COUS I NO , V IGO (PONTEVEDRA). 
**■ MARIANO LOF'EZ LOF-EZ, COLMENAR VIEJO (MADRID) . 

JAVIER CORONA DELGADO, RAMF'LONA . 
** FCO .. JAVIER DIAZ GARZON , BARCELONA. 

** J. MANUEL TRIAS COMPANY, SOLLER (MALLORCA). 
** PABLO VAQUERO SERULVEDA, AV I L.A . 
•» JESUS OCANA GOMEZ, MADRID. 

UN CRONOMETRO DE MICROUNO 

«* JUAN PENA SANCHEZ , ISLA CRISTINA ( HUELVA ) . 
«• ANGEL GOMEZ LOPEZ, LUGO. 

«* IGNACIO TIERNO MARTINEZ, BARCELONA. 

** MA . LUISA SANZ AGUADO, LLAVERNERS ( BARCELONA ) . 
"•» J. LUIS BLASCO CABAL, MADRID. 

UN LIBRO DE ANA YA MULTIMEDIA 

**■ ANTONIO CABEZA HERNANDEZ, TALAYERA (TOLEDO) . 

JAVIER MARTINEZ CORMENE Z ANA , BILBAO. 
♦*■ MIGUEL. SERRANO DEL. MAZO, CACERES. 
■» ECKART BCHILDER, BREXO (LA CORUNA) . 

**■ SANTIAGO DIAZ PEREZ, PORTUGALETE (VIZCAYA). 

•* RICARDO SEMPERE FALAU T OUART DE POBLET (VALENCIA). 

** FRANCISCO T' I NEO RAMIREZ, MATARO (BARCELONA) . 

MIGUEL ANGEL- FERNANDEZ, MADRID. 
*+ JORGE ABAD GIL-, MADRID. 
*•- EVA GOMEZ RODRIGO, SALAMANCA. 
■» F. JAVIER VAZOUEZ SERRANO, CORDOBA. 
«* J. CARLOS GARRIDO BERNARDEZ, ORENSE. 
** J. MIGUEL MELLADO BREY. SAN ROQUE (CADIZ) . 

•* SANTIAGO HERNANDEZ SANCHEZ, FUENLABRADA (MADRID). 
<.•*•< GINES CLIMENT PEREZ, VILLA JOYOSA (ALICANTE) . 



liminar, más otros que te permitan en- 
lazar el juego. 

Al dibujar este mapa, aeuérdate de 
marcar los sentidos en que se puede 
circular en cada habitación, porque 
puede ser que haya puertas que quie- 
ras que sólo puedan cruzarse en una 
dirección, acompañadas de un mensa- 
je tal como éste: 

LA PUERTA SE CIERRA DE 
GOLPE JUSTO DETRAS DE TI 

Las líneas de trazos que hay junto 
al cuarto oscuro indican que el aven- 
turero sólo podrá ir en esa dirección 
si se cumplen ciertas condiciones. En 
este caso, la condición es que el aven- 
turero tenga la lámpara y la haya en- 
cendido para poder ver las salidas. 

Es muy difícil predecir cuántos lu- 



gares se pueden meter en una canti- 
dad dada de RAM. La dificultad sur- 
ge porque hay muchas cosas que se 
disputan el espacio de memoria en el 
programa de la aventura: descripcio- 
nes de lugares, palabras que quieres 
que el programa reconozca, número 
de objetos y lo que quieres que se 
haga con ellos, número de enigmas y 
su complejidad, etc. 

Cuando hayas escrito unas cuantas 
aventuras pequeñas y comprobado 
cuánta memoria ocupan, tendrás una 
idea de lo que puedes meter en tu má- 
quina. 

Los poseedores de un ordenador de 
16K pronto descubrirán que es casi 
imposible escribir una aventura en 
gran escala en una cantidad tan peque- 
ña de RAM. Sin embargo, la aventu- 



ra que desarrollaremos en los siguien- 
tes capítulos sólo tiene unos pocos lu- 
gares — 12 en total — por lo que es su- 
ficientemente pequeña para no cau- 
sarte dolores de cabeza. 

El mapa para la búsqueda de la joya 
del globo ocular podría ser algo pare- 
cido al de la figura. En esta fase las 
descripciones de los lugares han de 
mantenerse cortas. Se han dibujado 
los enlaces y se ha decidido el punto 
de partida. Esto es muy importante, 
ya que afecta a la manera en que se 
aborda la aventura, al orden en que 
aparecen los objetos y se plantean los 
puzzles. 

También están marcados los obje- 
tos en sus lugares. Los objetos que 
aparecerán más tarde, por ejemplo la 
joya, es mejor listarlos a un lado del 
mapa. 

PASO DEL MAPA A LA RETICULA 

Cuando está completo el mapa, la 
información que contiene se puede 
transferir a una retícula. Hay dos ti- 
pos de retículas que se suelen usar al 
proyectar juegos de aventuras: una de 
ellas está basada en cuadrados, como 
en la figura siguiente, y la otra basada 
en octógonos. 
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En las aventuras más sencillas, sólo 
se podrá salir de cada lugar en una de 
estas cuatro direciones: Norte, Sur, 
Este y Oeste (así ocurre en la aventu- 
ra del globo ocular). Si tu aventura es 
de este tipo, tienes que transferir a la 
rejilla cuadrada toda la información 
para que resulte equivalente al mapa. 
Más adelante desarrollaremos esto 
con detalle. Si has utilizado salidas 
que incluyen Nordeste, Noroeste, Su- 
reste y Suroeste, tienes que emplear la 
retícula octogonal, aunque este tipo 
de rejillas resulta complicado. 

La última variante de la rejilla se 
produce si has decidido también subir 
y bajar. En este caso la mejor solución 
es utilizar una rejilla separada para 
cada «nivel» de aventura. 

La aventura del ojo precioso está 
basada sobre una retícula cuadrada, 
permitiendo sólo salidas por el Norte, 
Sur, Este y Oeste. A menos que haya 
una necesidad real de otras direccio- 
nes, este tipo de aventuras resulta muy 
adecuado y hay una manera de obviar 
las subjdas y bajadas. Si utilizas una 
descripción con frases como 

HAY UNA ESCALERA QUE 
BAJA HACIA EL OESTE 

puedes usar la respuesta normal del 
Oeste o la rutina adecuada. 



LA RETICULA 



Esta aventura requiere una retícula 
cuadrada de 6x4 como puedes com- 
probar contando el número máximo 
de lugares de tu mapa, de arriba a aba- 
jo y de derecha a izquierda. Antes de 
empezar a trasladar todos los detalles 
a la retícula, asegúrate de que has nu- 
merado todos los cuadrados. Empieza 
con el número 1 en la parte superior 
izquierda, y prosigue hasta llegar a la 
parte inferior derecha. Cuando hayas 
numerado todos los cuadrados y trans- 
ferido todos los detalles, la retícula 
será como la de la figura. 



EMPIEZA EL PROGRAMA 



Ahora tienes una línea histórica y 
una retícula completa, puedes empe- 
zar con el programa. 



El primer paso es teclear las des- 
cripciones de los lugares, basándote 
en tu retícula. Tienes que decidir 
cómo van a ser de largas. Intenta su- 
gerir lo más posible el ambiente de la 
aventura sin derrochar memoria. 
Aparte de las descripciones de los lu- 
gares, hay que decirle al ordenador en 
qué direcciones se encuentran las sali- 
das. 

Aquí tienes al fin las primeras sec- 
ciones del programa. Los números de 
líneas tan altos te permitirán disponer 
de suficiente espacio en las anteriores 
secciones de programa a medida que 
vayas desarrollando el juego. 

Teclea esta sección y almacénala 
(SAVE) en cinta: 



5000 REM ** DESCRIPCION DE 

UBICACIONES 
5010 REM ** UBICACION 4 
5020 PRINT'ESTAS EN EL 

EXTERIOR DE UN GRAN 

EDIFICIO" 
5030 N=0:E=0:S=1 :0=0:RETURN 
5040 REM ** UBICACION 7 
5050 PRINT'ESTAS EN UN RIO 

TURBULENTO" 
5060 N=0:E=1 : S=0 :0=0 : RETURN 
5070 REM ** UBICACION 8 
5080 PRINT'ESTAS EN UN BOSQUE 

PETRIFICADO" 
5090 N=0:E=0:S=1 :0=1 : RETURN 
5100 REM ** UBICACION 10 
5110 PRINT'ESTAS EN UNA SALA 

POLVORIENTA" 
5120 N=1 :E=1 :S=1 :0=0:RETURN 
5130 REM ** UBICACION 11 
5140 PRINT'ESTAS EN UN CUARTO 

OSCURO" 
5150 IF 0BC6)O-1 0R LA<>1 

THEN N=G:E=0 : SAO: 0=0 
5155 IF 0B(6)<>-1 0R LA<>1 

THEN PRINT'NO SE VEN LAS 

SALIDAS EN LA OSCURIDAD" 

: RETURN 

5160 M=0:E=0:S=1 :0=1 :RETURN 
5170 REM ** UBICACION 14 
5180 PRINT'ESTAS EN UN CAMINO 

LLENO DE BARRO" 
5190 N=1 :E=1 :S=0 : 0=0: RETURN 
5200 REM ** UBICACION 15 
5210 PRINT'ESTAS EN LA PUERTA 

DE LA CIUDAD OCULTA" 



5220 N=0:E=1 :S=0:0=1 .-RETURN 
5230 REM ** UBICACION 16 
5240 PRINT'ESTAS EN EL HALL 

DE ENTRADA" 
5250 N=1 :E=1 :S=1 :0=1 :RETURN 
5260 REM ** UBICACION 17 
5270 PRINT'ESTAS EN EL 

PATIO" 

5280 N=1 :E=1 :S=0:0=1 rRETURN 
5290 REM ** UBICACION 18 
5300 PRINT'ESTAS EN EL 

JARDIN" 
5310 N=0:E=0:S=1 :0=1 rRETURN 
5320 REM ** UBICACION 22 
5330 PRINT'ESTAS EN EL 

ARMARIO" 
5340 N=1 :E=0:S=0:O=0:RETURN 
5350 REM ** UBICACION 24 
5360 PRINT'ESTAS EN LA SALA 

DEL TRONO" 
5370 N=1 :E=0:S=0:0=0: 

RETURN 



No te preocupes por el abundante 
uso de las sentencias REM y toda la 
memoria que consumen. En esta pri- 
mera etapa del desarrollo del progra- 
ma es muy importante saber qué es lo 
que hace cada parte del mismo, o a 
qué número de lugar se refiere una 
descripción particular. Siempre pue- 
des quitarlas más adelante. 

Después de cada línea con la des- 
cripción de un lugar, hay otra línea 
que contiene información sobre sus 
posibles salidas. Las variables N, S, E 
y O significan Norte, Sur, Este y Oes- 
te. Estas variables pueden tomar uno 
de dos valores posibles: significa que 
no hay salida en esa dirección, mien- 
tras que 1 significa que hay salida. 

Finalmente, después de cada sec- 
ción de este programa hay un RE- 
TURN, debido a que cada descripción 
de lugar se llama mediante una sen- 
tencia GOSUB. 

La sentencia IF...THEN que hay en 
la sección del cuarto oscuro es para 
comprobar si el aventurero tiene la 
lámpara, pero la descripción de las va- 
riables se comentará más adelante 
cuando nos ocupemos de los objetos. 

En el próximo capítulo veremos la 
manera en que se mueve el aventure- 
ro por los distintos lugares. 
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CUARTO 
OSCURO 



HABITACION 
.POLVORIENTA 



16 



17 
PATIO 



VESTIBULO 
15 \DE ENTRADA 



JARDIN 



23 



24 

SALON 
DEL TRONO 



PUERTA 



21 



22 
ARMARIO 



El escenario final antes de empezar 
a programar. La rejilla es una copia di- 
recta del mapa en una forma que re- 
sulte más cómoda para trabajar con 
ella. 
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UNA AVENTURA 
MOVIDA 



PRESENTACION DE DIRECCIONES 
TRATAMIENTO DE LAS INSTRUCCIONES 



¡MOVIMIENTO A TRAVES DE LA AVENTURA 
I BLOQUEO DE LOS MOVIMIENTOS 

IMPOSIBLES 



Una parte de la diversión de jugar 
juegos de aventuras es la posiblidad de 
explorar mundos nuevos y extraños sin 
salir de casa. Veamos la manera de ini- 
ciar estas exploraciones. 



movimientos posibles en cada punto, 
y fijar unos límites, basándote en el 
grado de dificultad y en las pistas que 
se van recogiendo a medida que pro- 
gresa la aventura. 




Ahora que ya has tecleado un pro- 
grama que contiene todas las descrip- 
ciones de los ambientes, es el momen- 
to de hacer que el aventurero pueda 
explorarlos, desplazándose de un lu- 
gar a otro. Tienes que prever todos los 



En esta ocasión, para ampliar el de- 
sarrollo de tu programa de aventuras, 
presentaremos rutinas con la descrip- 
ción correcta de los ambientes, junto 
con las posibles salidas a los mismos. 
Al jugador se le pedirá que introduz- 



ca respuestas, y verás la manera de es- 
cribir una sección de programa para 
que el jugador se vaya moviendo por 
el interior del fantástico mundo, en 
base a las elecciones hechas, a medi- 
da que progresa la aventura. 



EL PUNTO DE PARTIDA 

Lo primero que el ordenador tiene 
que saber es dónde está el aventurero 
en cada momento del juego. Para ha- 
cer esto el programa mira al valor que 
va tomando una variable llamada L 
(de lugar). A esta variable se le asig- 
na un valor que corresponde al am- 
biente en que se encuentra el aventu- 
rero después de cada movimiento. 

Para empezar pues la aventura, tie- 
nes que decirle al ordenador dónde 
quieres que se encuentre el aventure- 
ro en el momento de empezar. 

Aquí tienes la primera parte de un 
programa que se encarga de esto. Car- 
ga (con LOAD) la sección que tecleas- 
te la última vez, y añádele las siguien- 
tes líneas: 

270 REM ** POSICION DE 

COMIENZO 
2 PC) L=15 
290 GCTC 330 



El número 15 corresponde al lugar 
en que se encuentra la puerta de la 
ciudad escondida. Si quieres que la 
aventura empiece en otro lugar, basta 
con que modifiques el valor de L. En- 
seguida veremos la forma de modifi- 
car el valor de L durante el juego, se- 
gún el lugar atravesado. Pero antes de 
que el aventurero pueda empezar a 
moverse, hay que decirle al ordenador 
hacia dónde tiene que ir. Para ello el 
aventurero utilizará el teclado, a tra- 
vés del que tendrá que introducir una 
o varias palabras. 



44 INPUT Juegos 



RESPUESTAS 



Para que el ordenador pueda enten- 
der adecuadamente tus respuestas, y 
actuar en consecuencia, tienes que 
proporcionarle una lista de todas las 
palabras que puede reconocer. 

En esta etapa del desarrollo, basta 
con que reconozca las cuatro direccio- 
nes NORTE, SUR, ESTE y OESTE. 
Podemos meterlas en una matriz R$, 



1?0 DIM R$CÍ9),RÍ19) :KEY OFF: 

WICTH 37:CLS 
130 FGR K-1 TO ¿«:READ R$(k> 

,R(K) :NEXT 
150 DATA NORTE, 1 ,SUR,1 ,ES T E,1 

, OESTE ,1 

En la línea 120 se dimensionan las 
matrices, de modo que contengan to- 
das las respuestas necesarias para el 
juego, dado que por el momento sólo 
necesitas utilizar las direcciones, sólo 
se emplearán los cuatro primeros ele- 



Pero evidentemente esta informa- 
ción no le sirve para nada al jugador, 
a menos que el ordenador le diga pre- 
viamente dónde se encuentra. 



LA BUSQUEDA DE UN LUGAR 



Para que el aventurero pueda saber 
adonde ha ido a parar después de cada 
uno de sus movimientos, hay que su- 
ministrarle una descripción de los lu- 
gares. Estas descripciones de lugares 




que contiene los datos de cada direc- 
ción de respuesta. 



110 REM ** MATRICES DE 
RESPUESTAS 



mentos de las matrices R$ y R. El bu- 
cle FOR ... NEXT de la línea 130, va 
desde uno hasta cuatro, leyendo tanto 
en R$ como en R. Las direcciones y 
sus números están en las sentencias 
DATA de la línea 150. 



ya las tienes tecleadas; sólo te hace fal- 
ta una rutina para extraer la descrip- 
ción que corresponda al valor de la va- 
riable L, el número de lugar. Aquí es 
donde resultan útiles las líneas REM 
que introdujiste anteriormente. 
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300 REM ** ENCONTRAR 
UEKACION 
CLS 

IF L<11 THEN CN L 



310 
330 



350 IF L<26 THEN ON L-2C 
GOSUB 0,5330,0,5360 

GOSUB O Antes de eseribir este tipo de ruti- 
,0,0,5020,0,0,5050,5080,0 ñas, tienes que asegurarte del número 



,5110: 




correspondiente a cada descripción de 
lugar. A partir del lugar número 1, tie- 
nes que ir haciendo una lista de los nú- 
meros de líneas de cada descripción. 
Si para alguno de los ambientes no hay 
ninguna descripción especial, asígnale 
un 0. En nuestra aventura, por ejem- 
plo, no hay descripciones para los lu- 
gares 1, 2 y 3, pero sí la hay para el 
lugar 4. 

Ahora que tienes la lista de los nú- 
meros de líneas, puedes empezar a es- 
cribir la rutina. Es una sencilla secuen- 
cia de operaciones de control del va- 



lor de L por medio de una sentencia 
ON ... GOSUB. 

La lista de números de líneas va 
desde la línea 330 a la 350, comenzan- 
do por el lugar 1 al principio de la lí- 
nea 330 y terminando con el lugar 24 
al final de la línea 350. 

PRESENTACION DE LAS 
DIRECCIONES 

Aparte de conocer las descripciones 
de los lugares, el jugador de la aven- 
tura querrá saber qué salidas tiene. 
Como en cada lugar no le será posible 
moverse en todas direcciones, el pro- 
grama debe tener alguna forma de 
controlar las informaciones asociadas 



GOTC 400 

340 JF L<21 THEN 0N L-10 

GOSUB 5140,0,0,5180,5210, 
5240,5270,5300,0,0 
:G0T0 400 
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con la dirección, es decir las variables 
N, S, E y O. La siguiente rutina dirá 
al aventurero qué direcciones son po- 
sibles: 



390 REM ** MUESTRA 
DIRECCION 

400 IF L<>11 OR (LA=1 AND 
0B(6)=-1) THEN PRINT 
rPRINTPUEDES IR ";:G0TC 
410 

405 GCT0 460 

410 IF N>0 THEN PRINT TABC11) 
"NORTE" 

420 IF S>0 THEN PRINT TABC11) 
"SUR" 

430 IF E>0 THEN PRINT TABC11) 
"ESTE" 



440 



IF 0>0 
"OESTE' 



THEN PRINT TABC11) 



La rutina se limita a comprobar el 
valor de las variables N, S, E y O, ba- 
sándose en el mapa de direcciones. Si 
el valor de las variables es mayor que 
cero, la dirección es posible y se pre- 
senta la correspondiente salida. 

Esta rutina puede ser incorporada 
tal como está en cualquier aventura 
basada en una retícula de cuadrados. 



INSTRUCCIONES 

Ahora que el aventurero ya conoce 
las direcciones que puede tomar, hay 
que hacerle algunas sugerencias. La si- 



guiente sección de programa le pre- 
guntará al jugador ¿QUE VAS A 
HACER AHORA? 

450 RF.M ** INSTRUCCIONES 
46C PRINT: JNPUT" AHORA 




QUE";IS 

470 G0SUB 3010 



Se trata de una rutina de entrada 
muy sencilla. A la respuesta suminis- 
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trada la llamamos 1$. El ordenador 
debe comprobar que la respuesta es 
correcta y actuar en consecuencia. La 
línea 470 envía el control a la subruti- 
na de la línea 3010, que es la encarga- 
da de procesar la respuesta dada por 
el jugador. 

3000 REM ** COMPRUEBA 

INSTRUCCION 
3010 N$="":F0R Z=1 T0 LEN(I$) 

:IF MID$(I$,Z,1)=" " 

THEN I=Z:60T0 3020 
3015 NEXT:I=0 
3020 IF 1=0 THEN V$=I$ 

:G0T0 3050 
3030 V$=LEFT$(I$,I-1) 
3040 N$=MID$(I$,I+1 ) 
3050 1=0 

3060 FOR K=1 T0 19 
3070 IF V$=LEFT$(R$(K), 

LEN(V$)) THEN I=R(K) 

:I$=LEFT$(V$,1) 
3080 NEXT 
3090 RETURN 

Esta rutina comprueba si 1$ contie- 
ne dos palabras. De ser así, llama V$ 
a la primera y N$ a la segunda. He- 
mos puesto V$ por verbo, como CO- 
GER, MATAR, o LLEVAR, y tam- 
bién sirve para las direcciones como 
NORTE, SUR, ESTE Y OESTE. N$ 
significa nombre, y vale para designar 
los objetos que aparecen en la aven- 
tura. El programa utiliza la sentencia 
MID$ (líneas 3010 a 3015) para exa- 
minar si hay un espacio entre V$ y N$. 

Si se encuentra un espacio, la línea 
3020 designa a las dos partes de 1$ con 
las etiquetas N$ y V$. Si no se encuen- 
tra espacio, la propia línea 3020 llama 
V$ a toda 1$. 

El resto de la subrutina (líneas 3060 
a 3080) compara las respuestas obte- 
nidas con las de la matriz R$, que con- 
tiene las direcciones de las respuestas. 
Más adelante veremos cómo puede 
ampliarse para contener una serie adi- 
cional de verbos. Si en la línea 3070 se 
detecta una coincidencia, se pone en I 
el correspondiente valor de R. En fa- 
ses posteriores del programa la máqui- 
na puede saber si ha habido una coin- 
cidencia examinando si I es mayor que 
cero. La última parte de la línea 3070, 



toma la primera letra de V$ y la llama 
1$, lo que servirá después para el mo- 
vimiento del aventurero. 

Esta subrutina puede utilizarse casi 
sin limitaciones en cualquier juego de 
aventuras. Probablemente la única 
modificación que le hagas, estará re- 



Py R 

¿Entenderá el programa res- 
puestas de dirección tales como 
NORTE o IR NORTE, además 
de letras solas, tal como N? 

La rutina de comprobación de 
instrucciones, situada en las lí- 
neas 3.000 a 3.090, está escrita 
de forma que admite palabras de 
cualquier número de letras. 
Cuando dos palabras van sepa- 
radas por un espacio el progra- 
ma las maneja de forma inde- 
pendiente. 

La línea 3.070 toma, como 
respuesta de dirección, la prime- 
ra letra. Siempre que esta pri- 
mera letra sea N, S. E u O (en 
mayúscula), el programa enten- 
derá lo que quiere decir el juga- 
dor, independientemente de 
cual sea la respuesta completa. 
Así pues: N, No y NORTE son 
respuestas válidas, pero no lo es 
IR NORTE. 

Sin embargo, no hay nada que 
te impida hacer adiciones que 
permitan al aventurero utilizar 
respuestas del tipo IR NORTE. 
Más adelante veremos cómo 
maneja el programa los verbos y 
los nombres. 

Lo que habrá que hacer será 
añadir IR a la lista de verbos y 
escribir una rutina de procesa- 
miento de esta nueva forma ver- 
bal. 



lacionada con la longitud del bucle 
FOR ... NEXT de la línea 3060. 



MOVIMIENTO 



Para que el aventurero pueda ex- 
plorar todos los lugares, basta que 



añadas al programa una rutina que 
transforme la variable de lugar L, se- 
gún el contenido de 1$. Aquí la tienes: 

1000 REM ** RUTINA DE 

MOVIMIENTO 
1010 IF I$="N" AND N>0 THEN 

L=L-6:G0T0 310 
1020 IF I$="E" AND E>0 THEN 

L=L+1 :G0T0 310 
1030 IF I$= M S" AND S>0 THEN 

L=L+6:G0T0 310 
1040 IF I$="0 M AND 0>0 THEN 

L=L-1:G0T0 310 
1050 REM ** SI NO HAY 

UBICACION POSIBLE EN TAL 

DIRECCION 
1060 PRINT:PRINT"L0 SIENTO" 

:PRINT"N0 PUEDES IR EN 

ESA DIRECCION!" 

:G0T0 330 

Recuerda que la aventura estaba 
basada en una retícula de seis por cua- 
tro. El movimiento implica un cambio 
del valor de L, que depende del tama- 
ño de la retícula. Moverse hacia el 
Norte o hacia el Sur equivale a sumar 
o restar 6 al valor de L para despla- 
zarse una línea hacia arriba o hacia 
abajo en la retícula. Análogamente, el 
movimiento hacia el Este o hacia el 
Oeste es equivalente a sumarle o res- 
tarle 1 al valor de L. 

Las líneas 1010 a 1040 comprueban 
las direcciones en 1$ y ajustan L en 
consecuencia. Sólo es posible el movi- 
miento si hay una salida que coincide 
con 1$. Las salidas fueron definidas en 
las líneas inmediatamente siguientes a 
las descripciones de los lugares. 

Si no existe salida en la dirección en 
que el aventurero quiere salir, la línea 
60 presenta el mensaje ¡LO SIENTO! 
¡NO PUEDES SALIR POR AHI! 

Para utilizar esta rutina con una 
aventura diferente, el único cambio 
que tendrás que hacer tendrá que ver 
con el tamaño de la retícula. En tal 
caso, habrá que modificar las líneas 
1010 a 1030, con arreglo a las líneas 
de la retícula. 

Almacena ahora el programa (con 
SAVE) dejándolo listo para ser utili- 
zado en el próximo capítulo. 
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Muchos abandonaron en el camino, pero otros (pocos) Llegasteis 
hasta el final en el reto planteado, Finalmente hubo que realizar 
un sorteo, imparcial por supuesto, al que asistimos elementos de 
la redacción de INPUT y personal de Anaya Multimedia. 
Los mensajes planteados tenían como respuesta lo siguiente: 



"ES UNA VIOLENCIA FINGIDA PUES SE TRATA DE 
UN TIPO DE CAJA INACCESIBLE A CUALQUIER 
TIPO DE PALANCA". 

" LAS ATADURAS NO SON DE UN PROFESIONAL DA 
LA IMPRESION DE QUE TENIAN MIEDO DE 
LESIONARLE". 

"TIENE LA COSTUMBRE DE MORDER LAS COLILLAS 
DE LOS CIGARROS QUE FUMA SIN PARAR HASTA 
DESHACERLAS". 

"EN EL REGISTRO EN LA CASA DE LA Victima 
aparecieron las joyas hábilmente CAMUFLADAS 
BAJO EL SUELO DEL DORMITORIO". 

"A PESAR DE ESTAR BASTANTE QUEMADA EN LA 
COLILLA SE PODIAN DISTINGUIR PERFECTAMENTE 
LAS MARCAS DEJADAS POR LOS INCISIVOS DE UN 
FUMADOR NERVIOSO". 



El intrépido y sagaz 
descifrador de claves se llama 
Manuel Bautista López. Todo un 
hallazgo para los servicios de 
inteligencia de cualquier 
pais, que no dudamos se lo 
rifarán cuando este ejemplar 
caiga en sus manos. Todo un 
criptofuturo por delante. 

En la fotografía podemos 
apreciar a nuestro afortunado 
Manuel disfutando de su 
estancia en el PCW Show de 
Londres. Le acompaña Santos 
Rodriguez, director de 
producto y delegado de Anaya 
Multimedia para el 
significativo evento. 
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Programación 



ORDENADORES, POZZLES 
Y MATEMATICAS 



TIPOS DE PUZZLES 



USO DEL ORDENADOR 



ECUACIONES SIMULTANEAS 
PRUEBA Y ERROR 



TRUCOS MATEMATICOS 



Agudiza tu ingenio y pon a prueba 
tu destreza en programación con estos 
difíciles rompecabezas. Al mismo tiem- 
po aprenderás unas cuantas técnicas 
nuevas para resolver sistemas de ecua- 
ciones. 

A estas alturas de nuestra andadu- 
ra en INPUT, ya debes tener una bue- 
na base en unas cuantas técnicas de 
programación en BASIC. Dado un 
problema cualquiera, deberías ser ca- 
paz de escribir un programa para re- 
solverlo (en el supuesto de que real- 
mente pueda ser resuelto). Pero a me- 
nos que tengas algún hobby especial o 
algún proyecto entre manos que haga 
uso del ordenador, con frecuencia es 
difícil pensar cosas con las que poner- 
se a hacer pruebas. 

Los rompecabezas ofrecen un desa- 
fío que suele ser bienvenido, ya que 
constituyen una forma entretenida de 
practicar la programación y de mante- 
ner al día tus habilidades. Han sido 
muy populares durante millares de 
años. Se sabe que los egipcios disfru- 
taban resolviendo rompecabezas y que 
los antiguos griegos eran extremada- 
mente aficionados a los rompecabezas 
y paradojas matemáticas y lógicas. De 
hecho muchos problemas que empeza- 
ron como un simple divertimento con- 
dujeron posteriormente a importantes 
descubrimientos en matemáticas y en 
otras ciencias. 

La resolución de un problema con 
éxito te hará sentir una sensación de 
satisfacción y, si participas en alguno 
de los cada vez más abundantes con- 
cursos organizados por las revistas de 
informática, puedes ganar muchos 
premios. Además, la solución de estos 
rompecabezas te enseñará sobre pro- 
gramación mucho más de lo que pue- 
des aprender por simples lecturas so- 
bre el tema ya que te obliga a traba- 
jar con tus propios métodos y a poner 
a prueba tus propias ideas. 



PUZZLES PARA ORDENADOR 

Existen muchos tipos de rompeca- 
bezas, pero no todos ellos resultan 
adecuados para ser resueltos por me- 
dio de ordenador. Muchos requieren 
una ¡dea feliz o un poco de razona- 
miento lógico. Un ejemplo clásico del 
tipo que requiere razonamiento lógico 
es el siguiente. Un hombre posee tres 
cosas: un lobo, una oveja y una ber- 
za, y tiene que transportarlas a la ori- 
lla opuesta de un río. Pero el bote que 
utiliza es muy pequeño y sólo puede 
llevar una cosa cada vez. Y si deja en 
tierra el lobo y la oveja, el lobo le ma- 
tará la oveja, mientras que si deja a la 
oveja y la berza, la oveja se comerá la 
berza. ¿Cómo puede hacer para pasar 
a la otra orilla del río las tres cosas 
conservándolas intactas? 

Este enigma puede resolverse con 
un ordenador (si te gusta, puedes in- 
tentar escribir un programa que lo 
haga), pero es mucho más rápido ha- 
cerlo con papel y lápiz o hacerlo di- 
rectamente de memoria. 

Los tipos de enigmas que mejor se 
resuelven por ordenador son los que 
contienen un cierto número de hechos 
y cifras y en los que se pide encontrar 
el valor de alguna incógnita. Otros 
que también funcionan bien sobre or- 
denador son los que exigen realizar ta- 
reas complicadas de tipo aritmético o 
geométrico. En tales casos es más rá- 
pido escribir un programa que resuel- 
va el problema que intentar hacerlo 
con papel y lápiz. 

Este artículo te enseñará cómo re- 
solver tres de los tipos más comunes 
de puzzles. Antes de mirar las solucio- 
nes, merece la pena que te entreten- 
gas en gastar algo de tiempo intentan- 
do resolverlos tú solo. Después, y si 
no has dado con la solución, pasa a 
consultar los programas y la explica- 
ción de su funcionamiento. 



SIMPLIFICACION DEL PROBLEMA 

Si no estás muy acostumbrado a re- 
solver adivinanzas, al principio puede 
que la cosa te resulte bastante difícil, 
ya que se requiere un poco de prácti- 
ca para separar la información esen- 
cial de la masa de palabras confusas 
que sólo sirve para despistar. De he- 
cho los enigmas del primer tipo se ba- 
san en las palabras que enmascaran lo 
que con frecuencia es un problema 
bastante sencillo. Cuando se le despo- 
ja de sus palabras, el enigma conduce 
habitualmente a la solución de un sis- 
tema de ecuaciones. Aquí tienes un 
sencillo problema que puedes resolver 
sin ordenador y que te ayudará a en- 
tender los principios que intervienen. 

Un grupo de amigos entra en un 
café y pide tres cafés y dos tés. La 
cuenta asciende a 176 pesetas. Al día 
siguiente se les agrega alguien más, y 
piden el doble de tés y un café menos. 
Esta vez la cuenta sube 16 pesetas 
más. ¿Cuánto cuesta la taza de té? 

Si eliminas toda la información no 
esencial y utilizas letras en vez de pa- 
labras, el problema se reduce a 3c + 
2t = 176 y 2c + 4t = 192. 

A esto se le llama un sistema de dos 
ecuaciones, porque han de satisfacer- 
se las dos al mismo tiempo. Para po- 
der resolver un sistema de ecuaciones 
se necesitan al menos tantas ecuacio- 
nes como incógnitas. En este caso hay 
dos incógnitas a las que hemos llama- 
do c y t, así como dos ecuaciones, por 
lo que el sistema en principio tiene so- 
lución. Además las ecuaciones son li- 
neales ya que ninguna de las variables 
aparece elevada a una potencia mayor 
que 1. Por ejemplo -3c 2 + 2t = 176 
es una ecuación no lineal que se re- 
suelve por un método diferente. 

Para resolver el problema puedes 
reordenar la segunda ecuación, lo que 
te dará c = (192 - 4t)/2 y a continua- 
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ción sustituir en la primera. Se obtie- 
ne 3(192 - 4t)/2 + 2t = 176. Reagru- 
pando de nuevo los términos, se ob- 
tiene t = 28, por lo que una taza de 
té cuesta 28 pesetas. 

Las ecuaciones con dos incógnitas 
como ésta son fáciles de resolver y las 
de tres incógnitas tampoco son dema- 
siado difíciles. Pero para un mayor nú- 
mero de incógnitas el ordenador resul- 
ta decisivo a la hora de hacer por tí el 
trabajo más duro. 

EL VENDEDOR DE SELLOS 

Aquí tienes el primer enigma real 
que debes resolver. 

Un vendedor de sellos tiene una 
caja con sellos extranjeros que piensa 
vender en paquetes de seis precios di- 
ferentes. El precio de los paquetes 
está codificado desde la A a la F. Seis 
jóvenes miembros de un club filatéli- 
co se presentan a la vez dis- 
puestos a gastarse todo el 
dinero que llevan en el bolsillo vi 1 
en lo siguiente: 

A B C D E F 1 07 AÜ 



Elena 6 2 

Jaime 14 11 

Anita 1 

Mar 5 3 

Luis 12 1 

Clara 8 



341 
469 
598 
376 
587 
293 



La pregunta es: ¿Cuál era el precio 
de cada paquete? 

El intentar resolver este sistema de 
ecuaciones eliminando una variable en 
cada paso, es posible, pero requeriría 
mucho tiempo y se presta a que se co- 
metan errores de cálculo. Con el si- 
guiente programa podrás resolver esta 
adivinanza así como cualquier otro sis- 
tema de ecuaciones lineales. Esta cla- 
se de sistemas se presentan en muchos 
tipos de problemas y no sólo en la re- 
solución de acertijos. 

Existen varias formas de resolver 
sistemas de ecuaciones como éste, y 
puedes encontrar métodos diferentes, 
pero el programa que sigue es rápido 
y relativamente corto: 



10 CLS:INPUT"NUMERO DE FILAS" 40 

;* 

15 INPUT'NUMERO DE COLUMNAS"; 

CrPRINI 
20 DIM A(R,C),B(R,C), 

A.$(C-1) 



50 
60 
70 



PRINTINCOGNITA DE LA 
C0LUN!NA";K; .-INPUT AS(K) 
NEXT SPRINT 
F0R J=1 TC R 

PRINT'COEFICIENTES DE LA 
FILA";J 




90 INPUT A(J,K) 
100 B<J,K>*A(J,lO 
110 ne>:t K:NEX1 J 
120 FCR L=1 10 R 
130 GGSUB 230 
140 GOSUB 280 
150 NEXT 
16C CLS 

17 FOP K--"1 TO C-1:PRINT 
TAB(8*K-7);A$(K); :NEXT 

:PRINT 

180 FCR J=1 TO P:FOR K=1 

10 C : PRIN7 TAB(K*8-8) 

;B(J,K); 
190 NEXT : PRINT :NEXT 
200 PRINT: PRINT 

'RESULTADOS ;-" 
210 FOR K=1 TO C-1 :PR1NT 

TAB(8*K-8);A(K,C); : NEXT 
??0 END 
230 REK 
240 D=A(L,L> 
250 FOR K=1 TO C 
260 A CL ,K) = A(L ,K) /D 
270 NEXT: RETURN 
280 REM 

290 FOR J=1 TO R 
300 IF J=L THEN NEXT 

: RETURN 
310 F=A(J,L) 
320 FOR K=1 TO C 
330 A(J ,K)«A(J,K)-F*A(L,lO 
340 NEXT : NEXT : RETURN 

La primera parte del programa, en- 
tre las líneas 10 y 110, te permite in- 
troducir los datos, mientras que la se- 
gunda parte, situada entre las líneas 
120 y 150 llama a dos subrutinas (o 
procedimientos) para calcular la res- 
puesta, la cual se imprime entonces en 
las líneas 160 a 220. 

Los valores se cargan en la matriz 
A(J,K) a razón de una fila cada vez. 
En este programa, J se refiere a las fi- 
las y K a las columnas, lo cual has de 
tener siempre en la mente al leer el 
resto del programa. La matriz A(J,K) 
se copia sobre una matriz idéntica 
B(J,K) de forma que se pueden impri- 
mir los valores originales junto con la 
respuesta en la línea 180. 

El cálculo avanza de fila en fila, 
controlado por el bucle que se extien- 
de entre las líneas 120 y 150. Antes de 
hacer otras cosas, la rutina de las lí- 



neas 230 a 270 extrae el elemento dia- 
gonal de la fila (es decir A(l,l), 
A(2,2), etc.) y divide cada elemento 
de dicha fila por ese valor. El valor del 
elemento diagonal resultante es ahora 
igual a uno, es decir, ha quedado nor- 
malizado. 

La siguiente rutina es la encargada 
de hacer la mayor parte del trabajo de 
este programa. Aunque sólo contiene 
seis líneas, resulta muy difícil exami- 
nar lo que hace. La mejor manera de 
entenderlo es examinar a fondo un 
ejemplo real (aunque corto) siguiendo 
uno por uno los pasos que va dando 
el ordenador. En esencia funciona de 
la siguiente manera. Supongamos que 
ya has normalizado la fila 1 , por lo que 
L es X. La línea 290 toma entonces 
cada fila diferente de la 1 (línea 300), 
por lo que en este caso empieza por 
la 2. La línea 310 toma el primer ele- 
mento de la fila 2 y le llama F. Toda- 
vía en la fila 2, la línea 320 va reco- 
rriendo todas sus columnas, y la línea 
330 multiplica F por el elemento co- 
rrespondiente de cada columna, pero 
de la fila 1, restándolo del elemento 
de la misma columna en la fila 2. Esto 
mismo lo va haciendo con las filas 3, 
4, 5 y 6. Seguidamente empieza otra 
vez con L igual a 2. 

AI final de este proceso, los elemen- 
tos diagonales de cada fila siguen sien- 
do 1 y todos los demás elementos son 
ceros. Por eso se pueden leer con fa- 
cilidad los valores en la columna de la 
derecha. 
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El programa que acabamos de ver 
sirve para resolver cualquier sistema 
de ecuaciones lineales en el que haya 
tantas ecuaciones como incógnitas. 
Pero existen rompecabezas en los que 
las cosas se organizan de tal manera 
que no hay ecuaciones suficientes, por 
lo que no se pueden resolver de esta 
forma. De hecho no existe una solu- 
ción única. El truco consiste en selec- 
cionar la respuesta más plausible en- 
tre todas las soluciones disponibles. 
Normalmente el enigma contendrá 
una clave que te ayudará. También 
podría ocurrir que las ecuaciones re- 



sultaran ser no lineales, como en el 
problema que te vamos a plantear. 

Ensaya el siguiente enigma. En Na- 
vidad, el tío Alberto, que es un mate- 
mático un poco excéntrico, explicó a 
sus dos jóvenes sobrinos que le daría 
a cada uno tantos paquetes como la 
edad que tenían (contando sólo los 
años). También les dijo que cada pa- 
quete contenía el mismo número de 
sobres que la edad de cada uno, y que 
cada sobre contenía un número de pe- 
setas igual a la edad de cada niño. 
Después de preparar los regalos, se le 
oyó murmurar entre dientes que el si- 
guiente año la cosa le iba a costar 500 
pesetas más. ¿Qué edades tenían los 
dos niños? 

Suprimiendo las palabras y llaman- 
do A y B a las edades de los niños, así 
como M a la cantidad de dinero gas- 
tada en este año, la solución del enig- 
ma queda reducida a la de las ecua- 
ciones siguientes: 

Af 3 + B |3 = M; 

(A + 1) f 3 + (B + 1) f 3 = M + 
500 

Tenemos tres incógnitas: A, B y M, 
pero sólo dos ecuaciones. Sin tener un 
ordenador, podrías utilizar un método 
de prueba y error para ir ensayando 
diferentes valores de A y B, y obser- 
vando si las ecuaciones se satisfacen. 
El ordenador trabaja de una forma pa- 
recida, salvo que naturalmente puede 
hacer varios cientos o miles de ensa- 
yos de valores diferentes en un tiem- 
po muy corto y sin cometer errores. 

El primer paso en la resolución del 
problema es buscar en el enunciado 
del enigma alguna pista suplementaria 
que te pueda ayudar a limitar el mar- 
gen de valores que debes ensayar. 
Como se habla de «jóvenes» sobrinos, 
no es probable que tengan más de 14 
años, y es muy probable que al menos 
tengan tres años. El programa para re- 
solver el problema es muy corto: 

10 FCR A^3 T0 14 

20 FOR B=A T0 14 

30 M=A A 3+B A 3 

40 N=(A+1) A 3+(B+1) A 3 

50 IF ABS CM+50G-NX.01 

THEN CLS:PRINT"LA SOLUCION 
ES:":PRINT "A="; A, "B=";B 
:END 



42 INPUT 




INPUT 43 



Programación 



60 NEXT B 
70 NEXT A 

Al ejecutar este programa obten- 
drás solamente una respuesta, debido 



a las restricciones introducidas en las 
líneas 10 y 20. Si en el enigma no se 
hubiera especificado que los sobrinos 
son jóvenes, el bucle FOR ... NEXT 
tendría que extenderse más. Digamos 
de paso que la condición impuesta en 
la línea 50 evita problemas con los 
errores de redondeo; lo que realmen- 
te se está comprobando es si se cum- 
ple que M + 50 es igual a N. 

Este método debe funcionar para 
todos los problemas con más incógni- 
tas que ecuaciones. En otros tipos de 
problemas, puede que te sea necesa- 
rio hacer hipótesis acerca de los valo- 
res de más variables, o tal vez incluir 
más condiciones IF ... THEN del tipo 
de la que aparece en la línea 50. Con 
un número muy elevado de incógnitas 
o de condiciones el programa puede 
tardar muchos minutos o incluso ho- 
ras en ejecutarse, aunque seguirá fun- 
cionando y resolverá, tarde o tempra- 
no, el enigma. 



MAGIA MATEMATICA 



El tercer tipo de rompecabezas que 
suelen aparecer en las revistas de in- 
formática son los problemas de núme- 
ros. Suelen plantear cuestiones de 
aritmética aparentemente sencillas 
que resultan extraordinariamente la- 
boriosas de resolver a menos que se 
utilice un ordenador. 

Aquí tienes un par de ejemplos. 

Existe un número de cuatro cifras 
que cuando se invierte y se multiplica 
por un entero se convierte en el nú- 
mero original: 8712 = 4*2178. El pro- 
blema es encontrar si existen más nú- 
meros con esta misma propiedad, y en 
caso afirmativo calcularlos. 

Otro número interesante es el 
987654321. Este número es un múlti- 



plo exacto de 17 y utiliza todos los dí- 
gitos del 1 al 9. Trata de encontrar el 
número inferior más próximo que ten- 
ga estas mismas propiedades. 

Las soluciones a este tipo de pro- 
blemas se basan en considerar el nú- 
mero como una colección de cifras 
más bien que como un valor numéri- 
co. Puedes, o dividir el número en uni- 
dades, decenas, centenas, etc, o tra- 
tarlo como una cadena de cifras y se- 
parar éstas con ayuda de RIGHT$, 
MID$ y LEFT$. 

El primer problema se resuelve me- 
diante el primer método. Si represen- 
tamos el número por ABCD, da ori- 
gen a la siguiente ecuación: 

1000*A + 100*B + 10*C + D = 
X*(1000*D + 100*C + 10*B + A) 

cuyas incógnitas tienes que calcular. 
Como de costumbre la principal difi- 
cultad consiste en decidir qué valores 
se ensayan. A puede variar entre 1 y 
9, no pudiendo ser cero ya que en ese 
caso tendrías un número de tres cifras. 
B y C pueden variar entre y 9. El fac- 
tor de multiplicación X debe ser al me- 
nos 2 y no debe superar a 10/D, para 
que el segundo miembro de la ecua- 
ción sea un número de cuatro cifras. 
Por la misma razón D no puede ser 
mayor que 4. Ahora puedes ya escri- 
bir el programa para resolver el pro- 
blema: 

10 FOR A=1 T0 9 

20 FOR B=0 T0 9 

30 FOR C=0 T0 9 

40 FOR D=1 T0 4 

50 FOR X=2 T0 INTC9.9/D) 

60 J=1000*A+100*B+10*C+D 

70 K=1000*D+100*C+10*B+A 

80 IF X*K=J THEN PRINT J; 

90 NEXT X,D,C,B,A 



ECUACIONES SINGULARES 

Hay algunas situaciones espe- 
ciales, con frecuencia bastante 
tontas, en que los sistemas de 
ecuaciones simultáneas tienen o 
una solución ambigua o carecen 
por completo de solución. Las 
ecuaciones x = 2 y x = 3 obvia- 
mente no pueden satisfacerse al 
mismo tiempo, e incluso cuando 
tiene tantas ecuaciones como in- 
cógnitas, como en el caso x + y 
= 3; x + y = 1 no pueden cum- 
plirse simultáneamente. 

Otro caso son las ecuaciones 
x + y = 2; 2x + 2y = 4. En este 
caso se trata de dos ecuaciones 
que no son independientes; 
esencialmente se trata de la mis- 
ma ecuación, existiendo muchas 
soluciones posibles. 

Cuando cuentes con el núme- 
ro de ecuaciones adecuado y 
siga habiendo incompatibilida- 
des o las ecuaciones no sean in- 
dependientes, se dice que el sis- 
tema es singular. 

El caso de las ecuaciones de- 
pendientes se puede resolver 
utilizando un método de prueba 
y error, como hacíamos en el 
caso de los regalos de Navidad. 
Pero al ser posibles varias solu- 
ciones necesitas alguna informa- 
ción adicional para seleccionar 
la correcta. 
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Teclea el programa, a continuación 
teclea RUN y siéntate a esperar por- 
que llevará bastante tiempo la com- 
probación de todas las combinaciones 
posibles. 

La solución del segundo problema 
trata a los números como cadenas. 

10 M=987654321# 
20 M=M-17 
30 M$=STR$(M) 
40 F=0 

50 F0R P=1 T0 9 

60 P$=CHR$(48+P) 

65 F0R Z=1 T0 LEN(M$) 

70 IF MID$(M$,Z,1)=P$ 

I NO OLVIDES © I 
EL TELEFONO... 

Cuando, por cualquier 
motivo, nos escribas. 



THEN 90 
80 NEXT Z:F=F+1 
90 NEXT P:IF F=0 THEN 

PRINT M$: END 
100 GOTO 20 

El programa parte de 987654321 y 
va contando hacia abajo de 17 en 17, 
convirtiendo cada múltiplo de 17 en 
una cadena de números a la que lla- 
ma M$. Las líneas 50 y 60 convierten 
cada dígito del 1 al 9 en una cadena y 
a continuación la línea 70 comprueba 
si dicha cadena figura en M$. Si hay 
algún dígito que no esté en M$, hay 
un indicador F que se incrementa una 
unidad. Sólo se imprime M$ cuando 
contiene todos los dígitos del 1 al 9. 



ECUACIONES SINGULARES 



Hay algunas situaciones especiales, 
con frecuencia bastante tontas, en que 
los sistemas de ecuaciones lineales tie- 
nen o una solución ambigua o carecen 



por completo de solución. Las ecua- 
ciones x = 2 y x = 3 obviamente .10 
pueden satisfacerse al mismo tiempo, 
e incluso cuando tienes tantas ecuacio- 
nes como incógnitas, como en el caso 
x + y = 3;x + y = lno pueden cum- 
plirse simultáneamente. 

Otro caso son las ecuaciones x + y 
= 2; 2x + 2y = 4 . En este caso se tra- 
ta de dos ecuaciones que no son inde- 
pendientes; esencialmente se trata de 
la misma ecuación, existiendo muchas 
soluciones posibles. 

Cuando cuentes con el número de 
ecuaciones adecuado y siga habiendo 
incompatibilidades o las ecuaciones no 
sean independientes, se dice que el sis- 
tema es singular. 

El caso de las ecuaciones depen- 
dientes se puede resolver utilizando 
un método de prueba y error, como 
hacíamos en el caso de los regalos de 
Navidad. Pero al ser posibles varias 
soluciones necesitas alguna informa- 
ción adicional para seleccionar la co- 
rrecta. 
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Si quieres ver tus programas, 



o artículos, 



tu revista, 



bases y haznos llegar 






publicados en 



examina 





el material. 



Publicar tiene su recompensa^ 





PROGRAMAS: Una vez desarrollado tu programa, 
que debe ser original y no haber sido enviado a ninguna 
otra publicación, puedes enviárnoslo aqui grabado en 
cassette, diskette o microdrive. Es preferible que vaya 
acompañado por un listado de impresora, pero no es 
imprescindible. 

El programa habrá de venir acompañado por un texto 
que aclare cuál es su objetivo, el modo de funciona- 
miento y una explicación del cometido que cumplen las 
distintas rutinas que lo componen. El texto se presenta- 
rá en papel de tamaño folio y mecanografiado a dos 
espacios. No importa que la redacción no sea muy clara 
y cuidada; nuestro equipo de expertos se encargará de 
proporcionarle la forma más atractiva posible. 
ARTICULOS E IDEAS: Se aplica lo anteriormente 
dicho para los textos que acompañan a los programas; 
es decir, conviene detallar al máximo lo que desees que 
aparezca publicado en la revista, de la manera que te 
gustaría que otra persona hubiera explicado eso mismo. 
UN JURADO propio decidirá en cada momento qué 
colaboraciones reúnen los requisitos adecuados para su 
publicación, y evaluará la cuantía del premio en metáli- 
co al que se hagan acreedoras. 

No olvidéis indicar claramente para qué ordenador está 



preparado el material, así como vuestro nombre y 
dirección y, cuando sea posible, un teléfono de contac- 
to. Entre todos los trabajos recibidos durante cada mes 
SORTEAREMOS: 

• Un premio de 50.000 ptas. 

• Un premio de 25.000 ptas. 

• Un premio de 10.000 ptas. 

en material microinformático a elegir por 
los afortunados. 

¡No os desaniméis!, por muy simples o complejas que 
puedan parecer vuestras ¡deas, todas serán revisadas 
con el máximo interés. 



INPUT MSX 

Alberto Alcocer, 46, 4/ 
28016 Madrid 



B 



NOTA: INPUT no se responsabiliza de la devolución del 
material que no vaya acompañado por un sobre adecuado con 
el franqueo correspondiente. 
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Cuando hayas terminado con W 
seño general de un programa, y hayas 
escrito todos los módulos individuales 
que lo constituyen, puedes empezar a 
pensar en la forma de probar los mó- 
dulos. Después tendrás que ocuparte 
de la forma en que vas a combinar y 
ensamblar entre si los distintos blo- 
ques. 

¿"La mayoría de las subrutinas y mó- 
dulos necesitarán unirse con el resto 
del programa de una u otra forma. 
Esto se hace normalmente utilizando 
variables. Algunas variables, que se 
especifican al principio, se pasarán a 
la rutina constituyendo lo que se lla- 
ma parámetros de entrada. Hay otras 
variables que serán introducidas en el 
programa por la propia rutina, son los 
parámetros de salida. Es muy impor- 
tante que las variables se especifiquen 
de forma precisa! 



ando empieces a escribir un pro- 
ama, debes hacer una lista de las va- 
riables que necesites usar, junto con 
una descripción de su uso y sus posi- 
bles valores, si los conoces. De no ha- 
cerlo así, aunque puede ser que a 





principio del programa sepas muy bien 
lo que significa cada letra, es más que 
probable que se te haya olvidado 
cuando vuelvas sobre el programa más 
adelante. Resulta de gran ayuda la uti- 
lización de nombres largos de varia- 
bles, en los casos en que tu ordenador 
lo permita y siempre que no andes 
muy escaso de espacio en la memoria. 

En el caso de tu MSX puedes tra- 
bajar con nombres de variables de 
cualquier longitud, con la única limi- 
tación de que no es posible superar, 
en una línea de programa (a menos 
que se utilice algún truco) la longitud 
de 255 caracteres. Teniendo esto en 
cuenta puedes trabajar perfectamente 
con una variable como ésta; funciona 
a la perfección... > ^^óy^X.^ f -*^^ 

10 ESTAESPROBABLEMENTELAVARIA 
BLEMASLARGAQUESEHAYAUTILIZ 



[NPROGRAMAALGUNOESTAESP 
R0BABLEMEN7ELAVAR I ABLEMASL 
ARGAQUESEHAYAUTTLIZADOENPR 
OGRAMAALGUNOESTAESPROBABLE 
MENTELAVARIABLEMASLARGAQUE 
SEHAYAUTIL IZADOENPROGRAMAA 
LGUNOESTAESPROBAELEMENTELA 
VARIAB=27 

Tiene nada menos que 240 caracte- 

Lo que sí tienes que tener en cuen- 
ta, para no llevarte sorpresas, es que 
tu ordenador sólo considera los dos 
primeros caracteres del nombre de 
cualquier variable (por ejemplo no 
distingue entre las variables VE y VE- 
LOCIDAD), así que por muy largo 
que pongas el nombre, asegúrate de 
que los dos primeros caracteres sean 
distintos a los del resto de las varia- 
bles que utilices. 

Aquí tienes un ejemplo de la forma 
en que podrías especificar las variables 
en una rutina de ordenación por el 
método de la burbuja: 

rutina de ordenación por el método 
de ia burbuja: 
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Avanza un paso más en la estructu- 
ración de tus programas, tomando 
como ejemplo la construcción de un 
programa de ordenación con el que po- 
drás ordenar desde bolas de billar has- 
ta las voces de un diccionario. 



■ 


SEGUIMIENTO DE LAS VARIABLES 


DEL PROGRAMA 


■ 


SUBRUTINAS 


■ 


COMO PROBAR LOS MODULOS 


■ 


PONIENDOLO TODO JUNTO 




ordenación de la parte especificada 
le una matriz según el orden alfabéti- 

Variables de entrada: 

A$(N) matriz unidimensional que 
se quiere ordenar (valor de N^l) 

NI primer elemento de la matriz 
que se quiere ordenar (l«£NlsSN2) 

N2 último elemento de la matriz 
que se quiere ordenar (N1^N2^ lon- 
gitud de A) 

Variables de salida: 

A$(N) matriz ordenada 

Variables temporales: 

Z, Z$. I 

Es útil anotar las variables tempo- 
rales utilizadas dentro de una subruti- 
na para evitar conflictos entre los mó- 
dulos o con el resto del programa. 
También te será de utilidad reservar 
algunas letras especialmente para di- 
chas variables temporales. Por ejem- 
plo, podrías usar de ZO a Z9. Con esto 
además consigues evitar el derroche 
de espacio para las variables. 

Si organizas bien todos estos aspec- 
tos al principio de la construcción de 
un programa, te ahorrarás muchos 
quebraderos de cabeza más adelante. 
Muchos errores de programación se 
deben a que las variables han sido co- 
rrompidas, es decir, han cambiado de 
valor cuando tú no esperabas que lo 



■rffan. Pero si sigues el métod< 

• } no tendrás ningún problema. 
La redacción de una lista de varia- 
bles también te será útil si alguna vez 
cambias el programa más adelante, ya 
que entonces será el momento de con- 
sultar la lista donde se especifica el 
modo en que se utilizan dichas varia- 
bles. Con esa lista te resultará mucho 
más rápida la modificación de las va- 
riables y te evitarás la introducción de 
nuevos errores en la programación, 
debidos a la corrupción de otras varia- 
bles que ya habían sido usadas para 
otros fines. Acuérdate de anotar las 
modificaciones que introduzcas, así 
como la fecha de las mismas. 

Aquí tienes ya el listado de la ruti- 
na de ordenación por el método de la 
burbuja. En las páginas siguientes tie- 
nes una explicación de su forma de 
funcionamiento y el correspondiente 
diagrama de flujo. 

1000 REM RUTINA DE ORDENACION 
DE UNA MATRIZ POR EL 
METODO DE LA BURBUJA 

1005 REM VARIABLES 
(A$(N) ,N1,N2) 

1010 Z=0 

1020 FOR I=N1 TO N2-1 
1030 IF A$(IX=A$(I+1) 

THEN GOTO 1060 
1040 SWAP A$(I),A$(I+1) 
1050 Z=1 
1060 NEXT I 
1070 IF Z=1 THEN 




GOTO 1 
1080 RETURN 

El programa anterior es 
una subrutina a la que- 
que llamar desde el programa 
principal. Por ejemplo, para orde- 
nar los elementos números 5 a 20. se 
podría llamar así a la subrutina: 

100 N1=5:N2=20 
:G0SUB 1000 

Siempre tiene que haber además 
una corta sección de programa para 
introducir los elementos que quieras 
ordenar, y otra sección que presente 
la lista ya ordenada. Llegados a este 
punto, tienes que decidir la forma en 
que quieres que aparezca el resultado 
en la pantalla, haciendo incluso algún 
dibujo sobre papel si ello te resulta de 
ayuda. 



PRUEBA DE LOS MODULOS 



Cada uno de los módulos de tu di- 
seño original terminará por convertir- 
se en una subrutina de tu programa. 
Este método de fraccionamiento del 
programa ayuda mucho durante la 





fase de pruebas, ya que cada 
los módulos puede ser probado y 
purado separadamente. La idea bási- 
ca consiste en definir las variables de 
entrada, llamar a la subrutina y exa- 
minar los resultados. Volviendo a la 
rutina de ordenación por el método de 
la burbuja, puedes hacer una prueba 
como la siguiente: 

8 CLS:INPUT"NUMERO DE 

ELEMENTOS";N 
10 DIM A$(N) 

12 CLS:PRINT"INTRODUCE L0S";N 

;" VALORES" 
14 FOR 1=1 TO N:INPUT 

A$(I):NEXT 1 
16 CLS:INPUT"RANGO PARA LA 

ORDENACION (N1,N2)" 

;N1,N2 
18 GOSUB 1000 
20 CLS:PRINT 

"LISTA ORDENADA" 
22 FOR 1=1 T0 N : PR INT A$(I) 

:NEXT I 
24 FOR J=1 T0 1000.-NEXT 

:G0T0 16 

Un aspecto importante a la hora de 
construir un programa a base de mó- 
dulos es incluir en cada uno de ellos 
lo que puede denominarse un «filtro». 
No se trata más que de un conjunto 
de líneas que se encargan de compro- 



tr que los parámetros de entrada al 
módulo son correctos. 

En un programa complejo resulta- 
ría imposible comprobar la corrección 
de todas y cada una de las entradas o 
salidas de los módulos. El programa 
se haría insoportablemente lento en su 
ejecución. 

Lo que si puede y debe hacerse es 
comprobar al menos los valores lími- 
te, de forma que el programa pueda 
detectar qué variables caen fuera de 
su rango permitido. 

Los filtros se suelen utilizar siempre 
que, en alguno de los módulos, haya 
entrada desde el teclado. Un ejemplo 
típico es el siguiente: 

1010 INPUT"ESCRIBE UN NUMERO 

(1-99)";N 
1020 1F N<1 0R N>99 THEN 

GOTO 1010 
1030 RETURN 

Otro consejo útil. Es una buena 
idea que, durante la etapa de prueba, 
todas y cada una de las líneas del pro- 
grama se ejecuten al menos una vez. 
Hay muchos errores que sólo se detec- 
tan cuando se ejecuta una determina- 
da línea. En el caso de saltos condi- 
cionales del tipo IF...THEN, debería 
hacerse la prueba para los dos posibles 
valores de la condición; verdadero y 
falso. 



Finalmente llega el momento de en- 
lazar todos los módulos y probar el 
programa como un todo completo. A 
esto se le llama integración del progra- 
ma. Si le has dedicado el debido tiem- 
po y cuidado a las anteriores fases del 
programa, este proceso de integración 
no debe producirte demasiados que- 
braderos de cabeza. No obstante si se 
producen problemas, tienes que vol- 
ver a comprobar todos los módulos 
sospechosos y modificarlos si es preci- 
so. Al final tienes que tener un pro- 
grama perfectamente estructurado 
que haga exactamente lo que tú quie- 
ras. 

Para refrescar tu memoria, aquí tie- 
nes las reglas que te conducirán a es- 
cribir un programa estructurado: 

1. - Escribe una descripción general 
del programa. 

2. - Fracciónala en módulos a todos 
los niveles que sea necesario. 

3. - Para cada módulo, dibuja un 
diagrama de flujo y define las varia- 
bles de entrada y salida, así como cual- 
quier otro detalle de interés, tal como 
la forma de presentación en pantalla. 

4. - Escribe los programas corres- 
pondientes a cada uno de los módu- 
los, utilizando las estructuras descritas 
en la primera parte de este artículo. 

Prueba cada uno de los módulos, 
dándole unas entradas y comproban- 
do los resultados. 

6.- Enlaza todos los módulos y rea- 
liza la prueba del programa completo: 
¡Tiene que funcionar! 



En caso de que te hayas olvidado de 
las razones que aconsejan que te to- 
mes todo este trabajo, recuerda que 
son la legibilidad, la comprobabilidad, 
la cambiabilidad, la fiabilidad y la 
transportabilidad; como puedes ver, 
un montón de «habilidades». 

Los programas estructurados son 
más fáciles de seguir por tí mismo y 
por los demás. Son más fáciles de de- 
purar y de modificar. Es más proba- 
ble que funcionen bien y resultan más 
fáciles de adaptar para que corran en 
otros ordenadores. Si tienes interés en 
cualquiera de estos resultados, tienes 
que pasarte a las técnicas estructura- 
das. 

FUNCIONAMIENTO DEL METODO 
DE LA BURBUJA 

Hemos utilizado el método de orde- 
nación de la burbuja para ilustrar la 
forma en que se puede construir y pro- 
bar un módulo antes de enlazarlo con 
el programa principal. Las rutinas de 
ordenación son muy útiles en cual- 
quier tipo de programas. Esta rutina 
sirve para clasificar palabras por orden 
alfabético, pero podría utilizarse 
igualmente para ordenar números por 
orden creciente o decreciente. No ten- 
drías más que cambiar la variables Z$ 
por Z y la matriz A$( ) por A( ). 

El ordenador lee la lista completa 
de elementos y los va comparando dos 
a dos. Si están en el orden correcto los 
deja como estaban, mientras que si es- 
tán desordenados los permuta. Conti- 
núa haciendo esto por toda la lista ha- 
ciendo una permutación tras otra has- 
ta que todos los elementos están en el 
orden correcto. 

Para ver mejor los detaUes de cómo 
funciona el programa, conviene com- 



pararlo con el diagrama de flujo. La 
primera parte del programa (que no 
se refleja en el diagrama de flujo) sir- 
ve para encontrar el número de ele- 
mentos que contiene la lista — N — y 
definir una matriz llamada A$( ) con 
espacio suficiente para N elementos. 
Las líneas 12 y 14 te permiten intro- 
ducir las palabras, que posteriormen- 
te serán ordenadas en la matriz; la lí- 
nea 16 te pregunta cuáles quieres or- 
denar. Si quieres ordenar toda la lis- 
ta, teclea 1, después una coma y des- 
pués el valor de N. La subrutina es lla- 
mada en la línea 18. 

La subrutina comienza poniendo a 
cero el valor de Z. A Z se le llama un 
indicador iflag) y registra si se han he- 
cho o no permutaciones. La línea 1020 
crea un bucle que recorre la lista com- 
pleta. Los números aseguran que cada 
pareja se compara una vez. La línea 
1030 compara las dos primeras pala- 
bras y si están en el orden correcto e 
programa salta sobre la rutina de- 
permutación yendo al siguiente 
par. 

A la línea 1040 sólo se 
puede llegar si las pala- 
bras están en orden in- 
correcto. En esta lí- 
nea se intercambian 
los valores que se 
están comparan 
do. 



Entonces se pone 
Z a 1 para indicar 
que al menos se ha hecho 
una permutación. La línea 1( 
envía al programa a comparar el 
siguiente par de palabras. 

Método de ta 




Una vez que han sido 
comparadas todas las pare- 
jas, el programa vuelve a la 
línea 1070. Si Z=l, significa 
que al menos se ha hecho una 
permutación, por lo que vuelve a re- 
correr la lista otra vez. Si no se han he- 
cho permutaciones, es porque la lista 
ya estaba ordenada, con lo que la su- 
brutina termina y las líneas 20 y 22 
presentan la lista ordenada. 



r^fewdeHordvva^ 



MITSUBISHI ML-G1 
Y ML-G3 



Buscando un puesto en el mercado 
de los ordenadores profesionales, Mit- 
subishi comercializa los modelos 
ML-G1 y ML-G3, de la segunda gene- 
ración MSX. Son unas máquinas de 
excelente acabado y con unas presta- 
ciones que están a la altura de lo que 
prescribe el estándar. 

Uno de los puntos fuertes del están- 
dar MSX es la variedad de equipos 
compatibles que lo forman. Desde sus 
inicios han sido muchas las marcas in- 
volucradas, lo que ha dado lugar, con 
los equipos de la primera generación, 
a un boom de modelos, todos ellos 
compatibles pero cada uno con sus ca- 
racterísticas propias. Algo parecido, 
aunque a mucha men¿r escala, está 
ocurriendo con los MSX2. En estas 
mismas páginas presentamos hace 
poco los modelos VG-8235 de Philips 
y HB-F500P de Sony. Ahora le corres- 
ponde el turno a Mitsubishi, que pre- 
senta dos modelos con aspiraciones: el 
ML-G1 y el ML-G3. 

Con ellos llega una oportuna diver- 
sificación de modelos dentro de la 
nueva versión del estándar, lo que 
puede ayudar a que éste se difunda y 
se consolide en un mercado tan com- 
plejo como el de la informática perso- 
nal. 



Consta de un bloque principal con el 
conjunto de teclas alfanuméricas, en- 
tre ellas la correspondiente a la letra 
Ñ, a la que hay que dar la bienvenida 
y que ha sido necesario incluir para 
que el sistema cumpliera las normas 
de homologación. A la derecha de 






ML-G1 



Es el pequeño de la gama MSX2 de 
Mitsubishi y sigue la filosofía de «in- 
cluir todo en una sola carcasa». Este 
todo está formado por la placa con los 
circuitos, el teclado y el conjunto de 
conectores para los periféricos. En la 
placa están los chips de la CPU Z-80A 
(que trabaja al ritmo de un reloj de 
3.579545 MHz), de la memoria RAM 
(64K de RAM principal y 128K de 
VRAM), de la memoria ROM (32K 
para el BASIC primera generación. 



16K para el BASIC expandido y otros 
32K para un programa de aplicación 
que lleva el nombre de Melbrains 
Note) y por último los chips de vídeo, 
de sonido y los que controlan el fun- 
cionamiento de los distintos conecto- 
res. El teclado es de «competición». 



este bloque principal nos encontramos 
con un teclado numérico independien- 
te (útilísimo a la hora de trabajar con 
programas tipo hoja de cálculo) y con 
el conjunto de las teclas de movimien- 
to de cursor. Una fila superior con las 
teclas de función y el conjunto de te- 
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cías especiales completan la geografía 
del teclado. Al tacto resulta inmejora- 
ble. No podemos poner, por más que 
lo intentemos, ni una sola objeción. 
Es suave, silencioso, todas las teclas 
resultan perfectamente accesibles y 
responden a la más ligera presión de 



interior de la carcasa, evitando ali- 
mentaciones externas que no hacen 
más que estorbar. Así que no hay (ni 
falta que hace) conector para la ali- 
mentación. Lo que si hay es un buen 
conjunto de conectores que incluyen 
los estándar MSX (joysticks, impreso- 




Ios dedos, sin rebotar ni repetir carac- 
teres. Es un teclado que impresiona y 
que sólo se puede catalogar como au- 
ténticamente profesional. 

Por último vamos con los conecto- 
res. El primer tanto se lo apunta Mit- 
subishi al incluir la alimentación en el 



ra, cassette y 2 cartuchos) a los que hay 
que añadir las salidas RF, de vídeo y 
RGB (para conectarse a cualquier tipo 
de pantalla) y una salida extra de la se- 
ñal de audio destinada a alimentar 
equipos de audio externos. 

En todo este conjunto hay sin em- 



bargo un gran ausente; la unidad de 
diskettes, no incluida en este equipo 
seguramente por razones de coste, 
para ofrecer un MSX2 a bajo precio. 
Pero no deja de resultar un tanto in- 
comprensible, que un equipo con pre- 
tensiones profesionales como éste no 
lleve incluida al menos una unidad. 
Hoy en día no tiene sentido utilizar un 
ordenador con fines profesionales a 
base de cassette. Se hace imprescindi- 
ble una unidad de diskette, que en el 
caso de este ML-G1 habrá que adqui- 
rir por separado, con los inconvenien- 
tes que ello supone. 

El equipo incluye todas las caracte- 
rísticas estándar de las máquinas de la 
segunda generación (que hemos resu- 
mido en un cuadro). Entre ellas hay 
que citar, por su especial atractivo, las 
del reloj en tiempo real, alimentado 
en este caso mediante una batería re- 
cargable que se carga a través de la red 
(esto garantiza que no habrá que cam- 
biar de pila). Esta opción permite que 
cualquier programa conozca, en cual- 
quier momento, la fecha y hora exac- 
tas. Las posibilidades que esto sugiere 
son infinitas. Otro elemento de inte- 
rés lo constituye la función RAM-disk 
(disco en RAM) que permite trabajar 
en memoria RAM como si se tratara 
de una unidad de discos, con la ven- 
taja de trabajar a una velocidad muy 
superior a la de cualquier unidad de 
discos. Eso si; al apagar el ordenador, 
toda la información almacenada en 
este disco RAM desaparece. Las ca- 
pacidades gráficas, desde las 80 co- 
lumnas del modo de texto, hasta la re- 
solución máxima de 512x212 puntos y 
la paleta de 512 colores, siguen sien- 
do el aspecto más llamativo y actual 
de las máquinas de esta generación. 

ML-G3 

Si el ML-G1 conserva, a pesar de 
sus características, un cierto aire a or- 
denador doméstico de la gama media 
(y la falta de unidad de disco lo con- 
firma), el ML-G3 se acerca mucho 
más a lo que puede considerarse as- 
pecto profesional. Consta de una car- 
casa, de color negro, que incorpora la 
unidad central, circuitería, conectores 
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y una unidad de diskettes de 3.5 pul- 
gadas, y de un teclado, separado de la 
carcasa a la que se conecta a través de 
un cable flexible. El teclado es exac- 
tamente el mismo que el del modelo 
ML-G1 y comparte con él unas exce- 
lentes características. 

El acabado de la unidad central es 
casi perfecto; los conectores están to- 
dos situados en el panel posterior del 
aparato, exceptuando los de los joys- 
ücks y el que conecta con el teclado, 
que se encuentran situados en uno de 
los laterales del equipo. En la parte 
frontal se localiza uno de los conecto- 
res de cartuchos, junto a la ranura de 
la unidad de diskettes. En el centro de 
este panel frontal, oculto por una 
tapa, hay un alojamiento previsto para 
incorporación de una segunda unidad 
de diskettes (desde luego una opción 
muy apetecible). En la parte poste- 
rior, además de los conectores men- 
cionados del modelo anterior, se ha 
incluido un conector para el interface 
serie RS-232C incorporado en el equi- 
po (otra opción a tener en cuenta, so- 
bre todo de cara al próximo futuro en 
el que las comunicaciones jugarán un 
papel importantísimo en la informáti- 
ca doméstica y profesional). 

La unidad de diskettes de 3.5 pul- 
gadas merece algunos comentarios. 
Trabaja con dos cabezas de lectura 
escritura, cada una de las cuales con- 
trola la grabación de 8() pistas de 9 
sectores cada una y con una capaci- 
dad de 5 1 2 bytes por sector. Esto pro- 
porciona una capacidad total de 720K 
por diskette una vez formateado (el 
doble que la estándar de las unidades 
de la primera generación que es de 
360K). 

La unidad es bastante rápida (es ca- 
paz de transferir 250Kbits por segun- 
do) y además es muy silenciosa. 

Sólo hay una pega, que en determi- 
nados casos puede tener su importan- 
cia, y es que el formato de grabación 
no es compatible con el de la primera 
generación. De esta forma aunque 
tengamos programas en diskette que 
puedan funcionar perfectamente en el 
ordenador, no podremos utilizarlos a 
menos que hagamos previamente una 
conversión de formatos de diskette. 



Otra de las novedades de este equi- 
po es el ya mencionado interface serie 
RS-232C. Se trata de un auténtico 
RS-232C, que configura al ordenador 
como Equipo Terminal de Datos. El 
conector es el estándar DB-25 de 22 
patillas en el que están representadas 
todas las señales importantes para la 
conexión. 
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Un par de chips (8251 y 8253)con- 
trolan la conexión y permiten la trans- 
misión de caracteres de 5 a 7 bits, con 
paridad seleccionable a voluntad y a 
velocidades que pueden variar entre 
50 y 19200 baudios (la velocidad pue- 



de ajustarse en valores distintos para 
transmisión y recepción). 

Un tema, en el que seguramente ha- 
brá bastantes expectativas, es el del 
tratamiento de imágenes y señales de 
vídeo. Existe un sistema actual de Mit- 
subishi para este cometido, pero por 
desgracia está adecuado al estándar de 
TV NTSC y no al sistema PAL. Aun- 
que se habla de una pronta adaptación 
del sistema a las normas de TV euro- 
peas, por el momento no hay otra so- 
lución que la de utilizar una cámara de 
vídeo y un monitor NTSC. 

Conectando estos dos elementos al 
digitalizador, que por el momento no 
viene incluido en los equipos, se po- 
drá trabajar con imágenes de vídeo de 
la misma calidad que las que reprodu- 
cimos en este artículo (pertenecientes 
a uno de los diskettes de demostración 
de Mitsubishi). 

SOFTWARE 

Ambos equipos incluyen de origen 
(en ROM en el modelo ML-G1 y en 
diskette en el ML-G3) un programa 
que lleva el nombre de Melbrains 
Note. Aún no hemos tenido ocasión 
de trabajar con este software que al 
parecer consta de los clásicos procesa- 
dor de texto, hoja de cálculo, base de 
datos, gráficos y comunicaciones. Es- 
peramos ofreceros una valoración de 
este paquete el mes que viene. 

El caso es que apenas hay más, por 
el momento. Mitsubishi no ha comen- 
tado el lanzamiento de ningún softwa- 
re específico que arrope a estas nue- 
vas máquinas, que por el momento 
tendrán que utilizar el de la primera 
generación, y esto con reservas pues 
hay unos cuantos programas que se re- 
sisten a cargar en las máquinas de la 
segunda generación aún funcionando 
perfectamente en las de la primera. 
Esto nos lleva a una consideración, 
elemental ciertamente, pero que no 
siempre se tiene en cuenta y es que 
por muy bueno que sea el hardware (y 
en este caso es excelente para el nivel 
de precio considerado) las máquinas 
sólo pueden llegar a ser verdadera- 
mente interesantes cuando van arro- 
padas por una buena cantidad de pro- 
gramas. 
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CARACTERISTICAS DEL ML-G1 




CPU: 


Z80A 


(3.579 MHz) 




MEMORIA: 


32K 


ROM (BASIC PRIMERA GENERACION) 




16K 


ROM (BASIC EXPANDIDO) 






32K 


ROM (MFIRRATN'í NOTF") 






64K 


RAM (PRINCIPAL) 






128K 


RAM (DE VIDEO) 




MODOS GRAFICOS: 





TEXTO MAXIMO 24 LINEAS 


X 80 COLUMNAS 




1 


TEXTO MAXIMO 24 LINEAS 


X 32 COLUMNAS 




2 


GRAFICO 256 X 192 EN 16 


COLORES 




3 


GRAFICO 64 X 48 EN 16 


COLORES 




4 


GRAFICO 256 X 192 EN 16 


COLORES (DE ENTRE 512) 




5 


GRAFICO 256 X 212 EN 16 


COLORES (DE ENTRE 512) 




6 


GRAFICO 512 X 212 EN 4 


COLORES (DE ENTRE 512) 




7 


GRAFICO 512 X 212 EN 16 


COLORES (DE ENTRE 512) 




8 


GRAFICO 256 X 212 EN 256 


COLORES SIMULTANEOS 


CHIP DE VIDEO: 


V9938 CHIP DE SONIDO: 


EQUIVALENTE AL AY38910 


CONECTORES: 


2 CONECTORES DE CARTUCHO (50 


TERMINALES) 




IMPRESORA, JOYSTICKS 






RADIO FRECUENCIA (TV), VIDEO 


COMPUESTO, RGB 




CASSETTE, SALIDA DE AUDIO EXTERNA 




CARACTERISTICAS DEL ML-G3 




MEMORIA: 


32K 


ROM (BASIC PRIMERA GENERACION) 




16K 


ROM (BASIC EXPANDIDO) 






16K 


ROM (DISK BASIC) 






8K 


ROM (RS-232C) 






64K 


RAM (PRINCIPAL) 






128K 


RAM (DE VIDEO) 




UNIDAD DE DISKETTES: 


CAPACIDAD: 1 MBYTE SIN FORMATEAR 






720KBYTES FORMATEADO 






VELOCIDAD: 250KBYTES POR SEGUNDO 






FORMATO: 3.5 PULGADAS 






DOBLE CARA (DOS CABEZAS) 






80 PISTAS/CABEZA 9 SECTORES/ PISTA 






512 BYTES/ SECTOR 


INTERFACE RS-232C: 




VELOCIDAD 








DE TRANSMISION: 50-19200 BAUDIOS 






BITS/ CARACTER: 5,6 ,7, l 


$ 






BIT PARIDAD: PAR, IMPAR NINGUNA 






LSI EMPLEADOS: 8251 Y 


8253 
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LOS MEJORES 
DE INPUT MSX 

PUESTO TITULO PORCENTAJE 

1° KnightLore 21,3% 

2° Soccer 16,4 % 

3.° H.E.R.O. 1 4,7% 

4° Alien 8 11,9% 

5° Profanador) 9,6 % 

6° Yiearkungfu 6,8% 

7. ° Hyper rally 5,6% 

8. ° River raid 5,3% 

9. " Jetfíghter 4,5% 

10.° Bounder 3,9% 



100% 

Para la confección de esta relación únicamente se 
han tenido en cuenta las votaciones enviadas por 
nuestros lectores de acuerdo con la sección «Los 
Mejores de Input». 

Octubre de 1986. 
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ABEJORROS SIDERALES 



Nuestras naves deben defender 
nuestra galaxia de los ataques de las 
malvadas naves enemigas. Ellos 
tienen todas las de ganar, puesto que 
son más y más poderosos; sin 
embargo, no cuentan con nuestra 
experiencia como pilotos, curtidos en 
mil combates como éste. 
El escuadrón enemigo está formado 
por tres clases de naves, los cazas 
azules, muy rápidos y de gran 
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movilidad, a los que podremos abatir 
de un solo disparo (si somos lo 
suficientemente rápidos para ello, 
claro); el platillo volante verde, de 
escasa movilidad pero de gran 
capacidad de disparo. Su campo de 
fuerza protector hace que debamos 
dispararle tres veces para abatirlo. 
Por último, tendremos que vérnoslas 
con la nave insignia. Esta nos atacará 
transcurrido un tiempo fijo desde 
que comienza el juego. Es 
completamente inmune a nuestros 
disparos, y la única forma de acabar 
con ella es hacer uso de la bomba. 
Pero para ello nuestra nave deberá 
contar con una suficiente carga de 
fuerza. Cada vez que derribamos un 
caza azul o un platillo volante verde. 




dejan libre su carga. Si nosotros la 
capturamos, aumentaremos la 
nuestra propia, hasta tener la 
suficente para poder atacar a la nave 
insignia antes de que ésta se dirija 
hacia nosotros. En caso contrario 
estaremos perdidos, ya que los 
disparos no la afectan en absoluto. 
Cuando acabemos con la nave 
insignia, accederemos a una segunda 
fase del combate. En ella nos 
atacarán las naves de la fase 
anterior, una tras otra, en ráfagas. 
Después tendremos que aterrizar con 
nuestra nave en un cráter. Luego 
accedremos a una nueva fase de 
combate, con nuevas naves y con 
mayores dificultades. Y así 
sucesivamente... Hay que hacer 
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mención especial del sonido de este 
programa. Aparte de los efectos de 
música y de explosiones, hay varias 
frases de voz sintetizada en inglés 
que impresionan por su claridad y 
realismo. Un verdadero prodigio de 
voz sintetizada con ordenador. 
El juego es divertido, dinámico y 
difícil. Aun siendo un clásico juego 
de marcianitos, sin excesivas 
novedades, la variedad de sus 
pantallas y su acabado casi perfecto, 
le convierten en una buena pieza 
para cualquier cazador de buenos 
programas. Verdaderamente, pone a 
prueba nuestra habilidad como 
pilotos de naves espaciales de 
combate. Pero seguro que saldremos 
airosos de la batalla. 



★★★★★★★★★★★★★★★★★★★★★★★★★★★★ 



EL PORTAVIONES 



Flight Deck es un programa con 
características muy interesantes que 
le sitúan más allá de lo que es común 
en juegos de ordenador. En primer 



lugar porque emplea una serie de 
dibujos digitalizados para construir 
los gráficos de determinadas partes 
del programa, entre ellas la pantalla 



de presentación. Con ello se 
consigue una calidad gráfica 
excelente, poco aprovechada sin 
embargo, pues la pantallas y áreas 
gráficas de mayor interés a la hora 
de jugar (es decir las zonas por las 
que se mueve el jugador) son 
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tratadas de forma convencional, con 
unos gráficos de mediana calidad. 
Además de la digitalización de 
imágenes, el programa hace uso, de 
cuando en cuando, de una serie de 
digitalizaciones esta vez de voz. Un 
par de frases suenan por el altavoz 
del televisor a la hora del despegue 
de los aviones desde la cubierta del 
portaviones. 

El argumento es bastante clásico: 
hay que llevar a cabo un ataque 
contra la base enemiga (situada en 
una isla) para destruir a las tropas 
allí situadas. Para ello el jugador 




tiene que controlar las evoluciones 
de los aviones y del portaviones a 
través de tres fases distintas, que se 
corresponden con distintas 
pantallas. 

La primera fase es la del despegue 
de los aviones. La segunda se 
desarrolla sobre un mapa y en la 



misma hay que dirigir 
adecuadamente todas las naves hacia 
el objetivo. La última fase tiene 



DATOS GENERALES 

TITULO Flight Deck 
FABRICANTE Bytebusters 

CLASE DE PROGRAMA 

Combate aereonaval 




CALIFICACION (Sobre 10 ptos.) 

ORIGINALIDAD 
INTERES 
GRAFICOS 
COLOR 
SONIDO 




lugar sobre la isla; es el ataque final. 
Este conjunto de fases proporciona 
la necesaria variedad de escenarios y 
situaciones para hacer el programa 
entretenido. 

Aunque técnicamente está bastante 
bien realizado, hay que decir que 
desilusiona comprobar que las 



digitalizaciones se utilizan más que 
nada para conseguir una buena 
presentación. Otros aspectos, quizá 





más imporrtantes, como la velocidad, 
la respuesta a los controles, los 
gráficos de las pantallas de acción e 
incluso el interés general del 
programa quedan un tanto deslucidos 
al lado de unos gráficos de 
presentación tan sumamente 
excepcionales. 



★ ★★★★★★★★★★★★★★★★★★★★★★★★★•A-* 



PALEOLITICO SUPERIOR 



¿Conseguirá Thor culminar con éxito 
su búsqueda del sentido de la vida? 
Este se encuentra perdido en las 
Montañas del Misterio. Allí Thor 
tendrá que enfrentarse a múltiples 
peligros, el mayor de los cuales es el 
terrible monstruo de las montañas 
Grog. 

En su periplo, Thor tendrá que 
recoger cuantas almejas pueda, ya 
que son la moneda con la que pagar 
a Peter, avispado negociante de la 
edad de piedra, e inventor del peaje. 
Para llegar al puente de Peter, paso 
obligado en la búsqueda, hay que 



pasar por las cuevas oscuras en las 
cuales, Thor deberá orientarse con 
ayuda de un faro, de invención suya 
(y precursor de las actuales 
linternas). Dentro de la cuevas 
también podrá recoger almejas, pero 
¡cuidado con las estalactitas! 
Cuantas más almejas recojamos, más 
ricos seremos para poder negociar 
con Peter. ya que además del peaje 
del puente, Peter es el único 
suministrador de ruedas en estos 
tiempos, y nos cobrará 25 almejas 
por una de repuesto. 
Tendremos que guiar a nuestro 



troglodita a través de los tortuosos 
caminos de la montaña, esquivando 
los baches y las rocas. Además, los 
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Tiredáctilos están hambrientos, y su 
principal alimento son las ruedas de 
piedra asi que ¡mucho cuidado con 
ellos! 

Pero el principal peligro es el terrible 
Grog. Si aparece en la misma 
pantalla que Thor, le destruirá con 
su terrible grito que hace temblar 



DATOS GENERALES 

TITULO International Karate 
FABRICANTE Endurance Games 

CLASE DE PROGRAMA 

Juego de Karate 

FORMATO Cassette 



CALIFICACION (Sobre 10 ptos. 



ORIGINALIDAD 

INTERES 

GRAFICOS 

COLOR 

SONIDO 



TOTAL 



39 




almejas, irá directamente a por 
nosotros. 

No cabe duda de que nos 
encontramos ante uno de los juegos 
más originales y divertidos que se 
han diseñado para MSX. La calidad 
de los gráficos y del color es 
excepcional, pareciendo realmente 
de dibujos animados. 
Hay tres montañas, en cada una de 
las cuales hay varios niveles de 
dificultad. El modo para efetuar el 




toda la montaña. Debemos evitar a 
Grog a toda costa, y al mismo 
tiempo, ser rápidos recogiendo 
almejas, ya que a él también le 
gustan para comer (con concha y 
todo), y cuantas más se coma, menos 
nos quedarán a nosotros. Además, si 
Grog termina de coger todas las 



cambio de nivel muchas veces 
tendremos que averiguarlo nosotros 
mismos, y este es otro de los 
alicientes del juego. 
En resumen, un juego dinámico, 
entretenido y absorbente, y uno de 
los mejores que han pasado por 
nuestras manos. 



★★★★★★★★★★★★★★★★★★★★★★★★★★★★ 

KARATE 

INTERNACIONAL 



Te enfrentas con un experto 
karateka en un torneo por el gran 
campeonato mundial, que se celebra 
en diversos países del mundo. 
En cada país, celebrarás un combate 
a tres asaltos, y ganando dos de ellos 
podrás pasar al siguiente combate en 
otro país distinto. 
Los asaltos duran un máximo de 
treinta segundos, a no ser que antes 
uno de los contrincantes sea 
derribado por su oponente. El juez, 
un anciano e imparcial maestro de 
karate, decidirá si el golpe vale 
medio punto (waza-ari) o un punto 



(ippon). El primero de los rivales 
que consiga dos puntos, habrá 
ganado ese asalto. 
Combinando los movimientos y el 
botón del joystick, podrás 
proporcionar una gran variedad de 
golpes de puño, golpes de pierna, 
saltos, esquivas, etc., que dan al 
combate un sorprendente realismo. 
Puedes elegir entre luchar con el 
ordenador, o con otro jugador. En el 
caso de hacerlo con el ordenador, 
ten cuidado, pues es un consumado 
cinturón negro que no te dará tregua 
ni descanso a lo largo del combate, y 
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tendrás que hacer uso de todas tus 

habilidades para derrotarle. 

Los efectos sonoros son muy buenos, 

destacando la voz sintetizada del 

maestro juez, que da la orden de 

comienzo y final del combate y 

marca el valor de los golpes. 

El efecto de realismo en los golpes y 

movimientos es muy bueno, pero el 

diseño de los karatckas es a nuestro 

juicio demasiado sencillo. 





★ ★★★★★★★★★★★★★★★★★★★★★★★■A-*** 



EL GRANJERO DE 
TRANSILVANIA 



Tras un complejo y enrevesado 
argumento (que podemos leer en la 
parte trasera de la carátula) en el 
que nos cuentan la historia de un 
granjero transilvano, de nombre 
Fred, que después de haber perdido 
la cosecha, se dedica a recoger fruta 
almacenada en un cercano castillo, 
armado nada menos que de una 
pistola láser, se esconde un programa 
de características poco relevantes. 
El personaje (Fred) tiene que 
desplazarse por diversas salas 
recogiendo frutas. En cada sala hay 




además una llave, necesaria para 
abrir la puerta que da paso a la sala 
siguiente. Para estorbar el trabajo de 
recolección de Fred, una serie de 
alimañas (arañas, escorpiones, y 
otros seres de aspecto extraño) se 
mueven de forma aparentemente 
aleatoria por los pasillos de cada 
sala. 

El programa aporta pocas 
novedades. No hay mapa ni 



continuidad entre unas salas y otras, 
por la sencilla razón de que una vez 
que se accede a la sala siguiente no 
hay forma de volver atrás. Esto 
significa que no hay scrollings. El 
paso de una pantalla a la siguiente se 
resuelve borrando y volviendo a 
dibujar. La diferencia entre pantallas 
es pequeña (otro color y algo más de 
complejidad). Con esta escasez de 
variedad el juego resulta bastante 
monótono. Los gráficos de los 
escenarios y personajes son sólo 
pasables. El movimiento, la 




velocidad y la respuesta a las 
acciones del jugador tienen un 
inevitable sabor a programa antiguo, 
de los que estaban de moda hace 
algunos años y en ningún modo son 
representativos de lo que se puede 
ver actualmente en programas para 
MSX. 



DATOS GENERALES 

TITULO Forbidden Fruit 
FABRICANTE Mind Games 

CLASE DE PROGRAMA 

Arcade 

FORMATO Cassette 




CALIFICACION (Sobre 10 ptos.) 


Con todo ello, el programa sólo 






resulta aceptable si pensamos en el 


ORIGINALIDAD 


5 


público infantil, en los más 


INTERES 


6 


pequeños; es sencillo de manejar y 


GRAFICOS 


7 


tiene un colorido agradable. 


COLOR 


8 




SONIDO 


6 


★★★★★★★★★ 


TOTAL 


32 





INPUT 61 



r 



^¡SodeSoftvAire 



EL REY DE LOS CIRCUITOS 



desarrollará toda su velocidad. 
El cambio de marchas consta de 6 
velocidades, y no es fácil escoger la 
más adecuada en función de las 
características de la pista. 
Al empezar el juego escogeremos 
circuito y nivel de dificultad, y 
podremos efectuar unas vueltas de 
práctica para familiarizarnos con él. 
La sensación de movimiento y de 
velocidad está muy bien conseguida, 




¡Sumérgete con este juego en el 
trepidante mundo de las carreras de 
motos! Tendrás que mostrar tu 
habilidad de consumado piloto en 
una carrera de alta velocidad contra 
19 expertos corredores. 
El campeonato mundial consta de 10 



carreras en diferentes circuitos de 
todo el mundo, cada uno de ellos 
con 3 niveles de dificultad. 
Encontramos complejas curvas, que 
pondrán a prueba nuestros nervios y 
sangre fría y largas rectas, en las que 
nuestra poderosa máquina 



pero los gráficos podían haberse 
mejorado mucho en calidad, ya que 
el dibujo de las motos no es real ni 
dinámico. 

¡Buena suerte, y a por el 
campeonato del mundo! 



★ ★★★★★★★★★★★★★★★★★★★★★★★a-*** 

EL VIAJERO DEL TIEMPO 



Magic Knight ha sido catapultado 
hacia un lejano futuro. Allí, una 
curiosa criatura de metal, llamada 
Klink. le ha suministrado un 



Datacubo, en cuyo interior se hayan 
almacenados todos los conocimientos 
y adelantos técnicos a los que la 
humanidad ha llegado en el 
siglo 25. 

Magic Knight irá absorbiendo los 
conocimientos con cuidado de que 
estos no le causen un grave shock, 
deberá regresar con ellos a nuestro 
tiempo, para que nuestra civilización 
pueda beneficiarse de los 
mismos. 

Pero para regresar, nuestro héroe 
tendrá que encontrar a los 
guardianes del tiempo, y resolver sus 
enigmas para obtener de ellos la 



máquina del tiempo que le permitirá 
regresar a nuestra era. 
No es tarea fácil, y para conseguirla, 
Magic Knight habrá de desenvolverse 
entre los múltiples peligros de ese 
tumultuoso siglo e incluso, a veces 
realizar un viaje espacial. 
A lo largo de su aventura, irá 
encontrando objetos tales como 
armas, alimento, planos, etc., que 
podrá examinar, recoger, usar o 
dejar, según sus necesidades de cada 
momento. 

No dudamos de que con nuestra 
ayuda, conseguirá llegar sano y salvo 
a nuestro tiempo y proporcionarnos 
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los adelantos de un remoto 
futuro. 

El juego es entretenido, pero tiene el 



defecto de ser muy parecido a otros 
juegos aparecidos con anterioridad, 
con lo cual pierde el aliciente de la 




DATOS GENERALES 

TITULO Knight Tyme 
FABRICANTE Mastertronic 

CLASE DE PROGRAMA 

Juego 



CALIFICACION (Sobre 10 ptos 



ORIGINALIDAD 

INTERES 

GRAFICOS 

COLOR 

SONIDO 



TOTAL 



36 



originalidad, uno de los principales 
atractivos de cualquier juego. 





★★★★★★★★★★★★★★★★★★★★★★★★★★★★ 



EL TRUENO AZUL 



¡Infíltrate con tu super-helicóptero 
en el territorio enemigo y lleva a 
cabo la peligrosa misión de rescate! 
Para lograrlo tendrás que convertirte 
en un experimentado piloto de un 
sofisticado helicóptero de combate 
dotado de las más poderosas y 
mortíferas armas, bombas y misiles; 
tendrás que esquivar los peligrosos 
misiles teledirigidos guiados por calor 
que te buscarán implacablemente y 





evitar los mortíferos disparos de las 
naves enemigas. 

Para culminar con éxito tu misión 
habrás de destruir la mayor cantidad 
posible de armas, carros de combate 
y fortificaciones en el territorio 
enemigo. Los depósitos de 
combustible enemigo que destruyas 
harán amuentar tu propio suministro. 
¡Ten cuidado con acercarte 
demasiado a tierra o a las 



fortificaciones enemigas, o serás 
destruido! 

El juego da a su comienzo 4 
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posibilidades, según escojamos 2 ó 4 
jugadores y la opción de joystick o 
teclado. El movimiento y los gráficos 
son estupendos (en la línea de todos 
los programas Konami) y hay que 



destacar la «mala idea» de los misiles aunque su diseño diste mucho de ser 



enemigos, con los que tendremos 
que desarrollar todas nuestras 
habilidades de piloto experimentado. 
Un juego entretenido y bien hecho. 



original; no puede dejar de 
recordarnos al famoso Scramble, por 
lo menos en cuanto a su idea básica. 



★★★★★★★★★★★★★★★★★★★★★★★★★★★★ 



¿HOMBRE O MOLECULA? 



Estamos seguros de que cuando el 
lector vea las fotos de este juego 
reconocerá otros de factura 
sumamente parecida. 




las monedas que se encuentran 
también escondidas. 
Con estas monedas también 
podremos adquirir bombas, que nos 




La única forma de que Molecule Man 

pueda escapar del laberinto es que 
reúna los 16 circuitos necesarios para 
activar el teleportador que es la 




En esta ocasión se trata de salvar a 
Molecule Man, que se encuentra 
perdido dentro de un complicado 
laberinto. Nuestros mortales 
enemigos son el tiempo y la 
radiación, que irán agotando nuestra 
vitalidad poco a poco, hasta acabar 
con nosotros. La única defensa 
contra la radiación son las pastillas 
que se encuentran escondidas a lo 
largo de todo el laberinto. Estas 




pastillas prolongarán nuestro tiempo 
de vida. Pero para conseguir las 
pildoras tendremos que disponer de 




servirán para llegar a lugares del 
laberinto que. de otra manera, serian 
inaccesibles. 



única vía de salida. ¡Pero primero 

tendrá que encontrarlos! 

Los gráficos 3D del juego están muy 

bien conseguidos, y serían muy 

llamativos si no hubieran sido usados 

ya en otros muchos juegos del mismo 

tipo. 

Por ello Molecule Man no es un 

juego original en absoluto, aunque si 
puede hacernos pasar unos ratos 
entretenidos, si bien no hay duda de 



que la repetición de la idea original 
pueda hacer que nos cansemos antes 
de él. 



★★★★★★★★★★★★★★★★★★★★★★★★★★★★ 
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Cambio más de 60 juegos comerciales 
(Profanation, Sorcery, Knight Lore, Soc- 
cer, Tennis...), y cassette especial para 
ordenador, por unidad de disco de 3.5 
pulgadas. 

Ramón Alonso 
Buenavista, 2B, etl.4 a 
Tel. (93) 564 39 06 
Monteada i Reixac (Barcelona) 



Compro, vendo, intercambio toda clase 
de juegos/programas educativos en 
MSX, incluso en disco. Llamar/escribir: 
Juan Mantencio Piulachs 
Marina, 292, 2", 1 a 
Tel. (93) 255 12 92 
08025 Barcelona 



Necesito la cinta-programa de la Table- 
ta Gráfica de Spectravídeo: SVI-105, o 
una copia de la misma, pues no la en- 
cuentro en ningún sitio, compensaré y 
gratificaré. 

Carlos Martínez Martínez 
Callejón del Moro, 1 
Huete (Cuenca) 



Cambio urgentemente un ordenador 
personal Spectrum 48K Plus por un 
MSX o 28.000 ptas. En caso de cambio 
por MSX se regalan cables, 15 juegos 
(Comando, Zorro, Panamá Joe, Krazy 
Kong, etc.). Se admiten de cualquier 
memoria. 

Juan José Escudero 
España, 25 
San Agustín (Almería) 



¡Oferta única! Cambio Yie-ar Kun-fu I y 
II, Tennis y Fútbol de Konami pasados 
a cinta por cualqueir cartucho de soft- 
ware. Preferiblemente de Pascal o En- 
samblador. Interesados ponerse en 
contacto con: 

Juan Carlos Oros 
Gasómetro 44, 1 o 3 a 
Tel. (977) 21 28 40 
43001 Tarragona 



azoco 

Cambio 18 programas cartucho, mayo- 
ría Konami, por cartucho ampliación de 
memoria de 64 Kb. Llamar o escribir a: 
José Manuel Vera Vilches 
Escritor José de los Heros, 3 
Tel. (957) 25 47 24 ó 27 48 67 
14014 Córdoba 



Vendo Hit Bit de Sony HB-55P (32 
Kbytes de RAM), ampliación de memo- 
ria (64 Kbytes) y 14 interesantes juegos; 
Hero, Turmoil, Zaxxon, Chess, Gun 
Fright, Sorsery, Simulador de vuelo, Bi- 
nary Land, Keysstone Kapers, Ensam- 
blador/Desensamblador, Les Flics, Nin- 
ja). Todo por 50.000 ptas, si te interesa 
llama o escribe a: 

David Butxaca Gros 
Serra Casa en Pons, 48 
Tel. (93) 821 15 40 
08600 Berga (Barcelona) 



Vendo ordenador Sony HB 55P MSX. 
Con cables, manual en español y caja 
de embalaje original. Comprado en na- 
vidades y completamente nuevo. El 
precio es de 15.000 ptas, por razones 
económicas. 

Daniel Díaz Sañudo 
Tel. (954) 70 56 33 
Sevilla 



Cambio cintas de juegos, poseo: 
Ghostbusters, H.E.R.O., simulador de 
vuelo, Ninja, etc. Precio a convenir. 
También desearía comprar el programa 
ZAXXON. 

José Casero Fernández 
Soto del Rey, 24 
Tel. 893 00 47 
Ciempozuelos (Madrid) 

Vendo libros «Hacia la Inteligencia Ar- 
tificial con Amstrad» y «Música y soni- 
dos con Amstrad» de Jeremy Vine, los 
dos por 1.500 pesetas. ¡Es una ganga! 

Vicente Uceda Alvarez 
Casiopea, 21 
Tef. 682 16 76 
Getafe (Madrid) 



Vendo ordenador Philips VG-8010. Más 
3 manuales y unos 30 juegos comercia- 
les. Con 3 meses de garantía. Precio a 
convenir. Escribir a: 

José Enrique Salvador 
Pesquera, 22 
Tel. (988) 12 28 86 
Aguilar de Campoo (Palencia) 



¡Oferta única! Por compra de un MSX 
2, vendo ordenador Philips MSX 
VG-8020 80K memoria (Teclado Profe- 
sional), poco uso, con manual BASIC y 
cables de conexión, sólo por 40.000 
ptas. 

Carlos Piñeiro Rodríguez 
Santo Domingo, 23 
Cangas (Pontevedra) 



¡Oferta Sensacional! Cambio Knignt 
Lore, Hero, Time Bandits, Gyro Adven- 
ture, Boulder Dash, Zaxxon por cartu- 
cho de ampliación de 64 Kb. Llamar o 
escribir a: 

Laureano Lama Pérez o José Carlos 
Arboleda, 59 
Tel. (954) 77 23 36 de 10 a 1 de la 

mañana 

41130 La Puebla del Río (Sevilla) 



Cambiaría programas Base de Datos 
Databa 32 K-MSX y Procesador de Tex- 
tos Compor 32 K-MSX, nuevos por 
otros programas de gestión o didácti- 
cos. 

J. García 
Apartado 20 
28080 Madrid 



Cambio juegos de cinta: Samuray Nin- 
ja, Hero, Zaxxon, Disc Warrior, Billar, 
Tank, River Raid, Congo Bongo, Chiller, 
Booga-Boo. Todos en perfecto estado. 
Me gustaría tener el Night Shade, Pro- 
fanation, Soccer. Enviar cinta a: 

Javier Rosando López 
Avda. de Concha Espina 
Tel. (942) 70 05 16 
39500 Cabezón de la Sal (Cantabria) 



Compraría cartucho de expansión de 
memoria marca Sony HBM-64. Para 
contactar llamar: 

Tel. (94) 681 49 30 (noches) 
Durango (Vizcaya) 



Intercambio programas y juegos MSX 
de todo tipo, poseo más de 100 (tam- 
bién cartuchos). Llamar a: 

Juan Manuel 
Tel. (954) 66 39 80 
Sevilla 



Vendo o Cambio juegos MSX, tengo 
más de cien títulos como King's Valley, 
Decathlon, Yier Ar Kunfu 1 y 2, Soccer, 
Star Avenger, Fórmula 1. Preguntar 
por: 

Manolo 
Tel. (954) 63 21 94 
Sevilla 



Intercambio programas de todo tipo 
MSX (excepto de revistas). Más de 150 
títulos. Escribir a: 

José M" Munguía 
Marqués de S. Esteban 42, 5°A 
Tel. (985) 34 04 77 
33206 Gíjón 



Vendo cartuchos de juegos siguientes: 
Hiper Sport 2, Track & Field I, Super 
Tennis, Eddy II. Todos en 15.000 ptas. 

Julio Leal Ruiz 
Comandante Paz Várela si. 
Edificio Parque Feria, 7 o C 
Tel. 31 15 15 
Jerez de la Frontera (Cádiz) 
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UN LIBRO DATA BECKER 

EDITADO POR FERRE MORET. S.A. 



MSX: EL MANUAL 
ESCOLAR 



Autor: Warner Voss 
Editor: Ferré Moret 
Páginas: 388 
Precio: 2.800 ptas. 

Intenta este libro de una for- 
ma didáctica ofrecer una pano- 
rámica de las posibilidades que 
nuestro ordenador MSX puede 
brindarnos dentro de diversos 
campos. 

El libro comienza con una 
introducción para iniciar al lec- 
tor en los comandos esenciales 
del lenguaje BASIC que nece- 
sitará según vaya avanzando en 
la lectura. 

Se pasa a continuación a los 
capítulos de aplicaciones, en 
los que el autor nos da una vi- 
sión del uso que podemos ha- 
cer en las áreas de matemáti- 
cas, química, física, idiomas, 
biología, ecología, geografía, 
historia y economía. 

Cada capítulo está dividido 
en una consideración previa, a 
la que siguen una serie de pro- 
gramas concretos que sirven de 
ejemplo de la aplicación consi- 
derada. 

En la consideración previa el 
autor trata de una manera ge- 
neral el sentido que tiene el uso 
del ordenador en el ámbito 
concreto del capítulo. Esta in- 
troducción es muy breve, pa- 
sándose inmediatamente a los 
programas. 

La presentación de los pro- 
gramas es muy didáctica y está 
completamente estructurada 
en 7 pasos. 

En el primero de ellos se da 
una breve presentación del 



problema que se pretende re- 
solver. Seguidamente se hace 
un análisis del problema, lle- 
gando a los resultados que se 
pretenden obtener y a la forma 
de conseguirlos. En el tecer 
paso se da el diagrama de flujo 
u organigrama de la resolución 
del problema, para después dar 
un listado del mismo. 

A continuación hay una lista 
de las variables utilizadas por 
el programa y del cometido de 
cada una. para comentar segui- 
damente una a una todas las lí- 
neas del listado. teiTninando 
con una explicación de cómo se 
presentan los resultados. 

Como vemos, un ordena- 
miento tan completo de cada 
problema hace que este libro 
sea muy adecuado como instru- 
mento de enseñanza y de au- 
toaprcndizaje del lenguaje 
BASIC y de las aplicaciones de 
nuestro ordenador MSX. 

Por todo ello, MSX, el ma- 
nual escolar es un libro alta- 
mente recomendable para el 
principiante en estos meneste- 
res y, en cualquier caso, muy 
ameno y curioso para cualquier 
lector interesado en saber qué 
posibilidades le ofrece real- 
mente su ordenador. 



GAMES FOR YOUR 
SPECTRAVIDEO 



Autor: Damon Pillinger y 
Danny Olesh 
Editor: Rama 
Páginas: 124 
Precio: 1 .000 ptas. 
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Encontramos en este libro 
otro de los muchos compendios 
de juegos y sencillas utilidades, 
encaminados a que nosotros 
mismos las introduzcamos en el 
ordenador y las grabemos, 
para incorporarlas posterior- 
mente a nuestra biblioteca. 

Este libro presenta una serie 
de 27 pequeños programas, 
principalmente de juegos, es- 
critos en BASIC. La descrip- 
ción de cada juego consiste en 
un pequeño comentario inicial, 
en el que se describe de forma 
muy sucinta el objetivo de cada 
programa, para pasar después 
a dar el listado del mismo. 

A nuestro juicio, los progra- 
mas contenidos en el libro no 
son de excesiva calidad, exis- 
tiendo algunos (dibujo de cír- 
culos, dibujo de formas de 
onda), que después de ser eje- 
cutados una vez y observado el 
efecto visual, se nos antojan de 
poca utilidad posterior. 

Por otra parte, el pequeño 
comentario que se hace al co- 
mienzo del programa podría 
ser más amplio, ya que , aun- 
que los programas son sencillos 
en su mayoría, el lector podría 
aprender mucho más si se le 
explicara con detalle cómo es- 
tán hechos. 

No obstante, entre los 27 
programas que componen este 
libro existen algunos consegui- 
dos y entretenidos. Podría ha- 
berse dedicado más espacio 
para mejorar éstos (incluyendo 
por ejemplo, rutinas en código 
máquina para mayor rapidez) 
en lugar de introducir muchos 
otros pequeños programas de 
peor calidad. 

En resumen, (¿ames for your 
Spectravideo puede ser califica- 
do como un compendio más de 
juegos sencillos para nuestro 
ordenador. Dada la sencillez 
de los programas que contiene, 
va destinado principalmente a 
aquellas personas que se ' ini- 
cian en el manejo de un orde- 
nador MSX. 



DESCUBRE TU MSX 



Autor: Joe Pritehard 
Editor: Anaya 
Páginas: 232 
Precio: 1.272 

Descubre tu MSX es un libro 
bastante completo que explica 



de forma clara y concisa todo 
lo que el usuario de un ordena- 
dor del estándar saber, para sa- 
car el máximo partido de su 
máquina. 

El desarrollo de la obra es 
gradual, partiendo de una in- 
troducción al estándar MSX y 
de las sentencias esenciales del 
BASIC, y termina con unas no- 
ciones de código máquina, 
dando la información necesaria 
para que cualquier lector pue- 
da hacer sus primeros «pinitos» 
con este tipo de lenguaje. 

Entre un tema y otro se to- 
can todas las materias que tie- 
nen que ver con la programa- 
ción de nuestro ordenador, ta- 
les como estructuras de datos, 
almacenamiento de datos y 
programas en cassette, formato 
de variables, gráficos, sonido, 
programación de juegos, etc. 




Se da asimismo algunas ruti- 
nas sencillas que el lector pue- 
de usar en sus propios progra- 
mas, ahorrándose tiempo y tra- 
bajo. 

Un capítulo interesante es el 
dedicado al mapa de memoria 
del MSX. Este capítulo será, 
sin duda, bien recibido por la 
inestimable ayuda que nos 
ofrecerá en muchas de nuestras 
aplicaciones. 

En definitiva. Descubre tu 
MSX es un estupendo libro de 
consulta, que no debería faltar 
en la biblioteca de ningún 
usuario de este tipo de ordena- 
dores, ya que puede servir 
como libro de consulta al pro- 
gramador experimentado y 
como libro de estudio para 
todo el que quiera dar los pri- 
meros pasos en programación. 
Todo ello gracias al rigor, exac- 
titud y sencillez a la hora de 
tratar los temas incluidos. 
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MSX ■ 
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SPECTRUM 



MOLECULE MAN 

Perdido en un laberinto de 
256 habitaciones lucha en con- 
tra del tiempo y las radiaciones 
letales para teleportarte a 
lugar seguro. También incluido 
en esta cinta un único y fácil 
de utilizar, sistema de constru- 
cción de laberintos, que te 
permitirá corregir el existente 
o crear otros nuevos. 

MSX 

COMMODORE 




SPEEDKING 

El juego de carreras de Moto- 
. cicletas con la emocionante 
acción de correr rueda con 
: rueda contra otros 19 pilotos 
jPonte el casco y vive la inol- 
vidable aventura de las motos 
de altas prestaciones compi- 
tiendo a 250 millas a la hora! 



MSX 
AMSTRAD 
SPECTRUM 




MSX 
AMSTRAD 
SPECTRUM 



KNIGHTTYME 

La tercera de la serie de aven- 
turas Magic Knight, se encon- 
tró a sí mismo transportado 
al siglo 25 abordo de la nave 
estelar PISCIS. El juego utili- 
za un sistema mejorado de 
animación, que fue utilizado 
por primera vez en Spellbound. 
¿Será éste el fin de Magic 
Knight?. 

SERIE M.A.D.: P.V.P. 1.100 PTAS. 




FORMULA 1 

El juego de competición de 
mayor realismo, con los diez 
circuitos más famosos; 
SILVERSTONE, MONACO, 
MONZA... etc. 

¡3, 2, 1... Adelante! 




CHILLER 

En una fría noche de Luna llena 
intentarás salvar a tu chica 
enfrentándote a cadáveres 
vivientes, arañas, espectros 
y murciélagos. 
¡Animo y recoge todas las 
cruces que puedas! 




SPACE WALK 

Eres un astronauta al mando 
de la Lanzadora Espacial. 
Desde tu base en la luna vigilas 
los satélites , descarriados y 
tienes que recuperarlos. Tra- 
baja por la superficie de la luna 
V cuando sea necesario utiliza 
el JET-PACK para propulsarte 
al satélite. 

Licencia exclusiva para ESPAÑA ORO SOR 

Fundadores, 3 28028 MADRID 
Tais. 255 45 00/09 



YA A L A VEIMTA 

tus primeros programas de apuestas 
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